Merge branch 'develop' into test/jenkins
This commit is contained in:
commit
7ca3dba05a
|
@ -9,6 +9,7 @@ ADD_SUBDIRECTORY(lz4)
|
||||||
ADD_SUBDIRECTORY(cJson)
|
ADD_SUBDIRECTORY(cJson)
|
||||||
ADD_SUBDIRECTORY(wepoll)
|
ADD_SUBDIRECTORY(wepoll)
|
||||||
ADD_SUBDIRECTORY(MsvcLibX)
|
ADD_SUBDIRECTORY(MsvcLibX)
|
||||||
|
ADD_SUBDIRECTORY(rmonotonic)
|
||||||
|
|
||||||
IF (TD_LINUX AND TD_MQTT)
|
IF (TD_LINUX AND TD_MQTT)
|
||||||
ADD_SUBDIRECTORY(MQTT-C)
|
ADD_SUBDIRECTORY(MQTT-C)
|
||||||
|
|
|
@ -38,6 +38,7 @@
|
||||||
typedef int clockid_t;
|
typedef int clockid_t;
|
||||||
/* Supported values for clockid_t */
|
/* Supported values for clockid_t */
|
||||||
#define CLOCK_REALTIME 0
|
#define CLOCK_REALTIME 0
|
||||||
|
#define CLOCK_MONOTONIC 1
|
||||||
|
|
||||||
int clock_gettime(clockid_t clock_id, struct timespec *tp);
|
int clock_gettime(clockid_t clock_id, struct timespec *tp);
|
||||||
|
|
||||||
|
|
|
@ -34,15 +34,56 @@
|
||||||
#include "msvcTime.h"
|
#include "msvcTime.h"
|
||||||
#include "sys/msvcStat.h" /* For MsvcLibX's Filetime2Timespec */
|
#include "sys/msvcStat.h" /* For MsvcLibX's Filetime2Timespec */
|
||||||
|
|
||||||
int clock_gettime(clockid_t clock_id, struct timespec *pTS) {
|
#define MS_PER_SEC 1000ULL // MS = milliseconds
|
||||||
FILETIME ft;
|
#define US_PER_MS 1000ULL // US = microseconds
|
||||||
if (clock_id != CLOCK_REALTIME) {
|
#define HNS_PER_US 10ULL // HNS = hundred-nanoseconds (e.g., 1 hns = 100 ns)
|
||||||
errno = EINVAL;
|
#define NS_PER_US 1000ULL
|
||||||
return -1;
|
|
||||||
|
#define HNS_PER_SEC (MS_PER_SEC * US_PER_MS * HNS_PER_US)
|
||||||
|
#define NS_PER_HNS (100ULL) // NS = nanoseconds
|
||||||
|
#define NS_PER_SEC (MS_PER_SEC * US_PER_MS * NS_PER_US)
|
||||||
|
|
||||||
|
int clock_gettime_monotonic(struct timespec *tv) {
|
||||||
|
static LARGE_INTEGER ticksPerSec;
|
||||||
|
LARGE_INTEGER ticks;
|
||||||
|
double seconds;
|
||||||
|
|
||||||
|
if (!ticksPerSec.QuadPart) {
|
||||||
|
QueryPerformanceFrequency(&ticksPerSec);
|
||||||
|
if (!ticksPerSec.QuadPart) {
|
||||||
|
errno = ENOTSUP;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
GetSystemTimeAsFileTime(&ft);
|
|
||||||
Filetime2Timespec(&ft, pTS);
|
QueryPerformanceCounter(&ticks);
|
||||||
|
|
||||||
|
seconds = (double) ticks.QuadPart / (double) ticksPerSec.QuadPart;
|
||||||
|
tv->tv_sec = (time_t)seconds;
|
||||||
|
tv->tv_nsec = (long)((ULONGLONG)(seconds * NS_PER_SEC) % NS_PER_SEC);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int clock_gettime_realtime(struct timespec *pTS) {
|
||||||
|
FILETIME ft;
|
||||||
|
|
||||||
|
GetSystemTimeAsFileTime(&ft);
|
||||||
|
Filetime2Timespec(&ft, pTS);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int clock_gettime(clockid_t clock_id, struct timespec *pTS) {
|
||||||
|
if (clock_id == CLOCK_MONOTONIC) {
|
||||||
|
return clock_gettime_monotonic(pTS);
|
||||||
|
} else if (clock_id == CLOCK_REALTIME) {
|
||||||
|
return clock_gettime_realtime(pTS);
|
||||||
|
}
|
||||||
|
|
||||||
|
errno = ENOTSUP;
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* defined(_WIN32) */
|
#endif /* defined(_WIN32) */
|
||||||
|
|
|
@ -0,0 +1,11 @@
|
||||||
|
AUX_SOURCE_DIRECTORY(${CMAKE_CURRENT_SOURCE_DIR}/src SOURCE_LIST)
|
||||||
|
|
||||||
|
add_definitions(-DUSE_PROCESSOR_CLOCK)
|
||||||
|
|
||||||
|
INCLUDE_DIRECTORIES(${CMAKE_CURRENT_SOURCE_DIR}/../MsvcLibX/include)
|
||||||
|
|
||||||
|
ADD_LIBRARY(rmonotonic ${SOURCE_LIST})
|
||||||
|
TARGET_INCLUDE_DIRECTORIES(rmonotonic PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/inc)
|
||||||
|
IF (TD_WINDOWS)
|
||||||
|
TARGET_LINK_LIBRARIES(rmonotonic MsvcLibXw)
|
||||||
|
ENDIF ()
|
|
@ -0,0 +1,56 @@
|
||||||
|
#ifndef __MONOTONIC_H
|
||||||
|
#define __MONOTONIC_H
|
||||||
|
/* The monotonic clock is an always increasing clock source. It is unrelated to
|
||||||
|
* the actual time of day and should only be used for relative timings. The
|
||||||
|
* monotonic clock is also not guaranteed to be chronologically precise; there
|
||||||
|
* may be slight skew/shift from a precise clock.
|
||||||
|
*
|
||||||
|
* Depending on system architecture, the monotonic time may be able to be
|
||||||
|
* retrieved much faster than a normal clock source by using an instruction
|
||||||
|
* counter on the CPU. On x86 architectures (for example), the RDTSC
|
||||||
|
* instruction is a very fast clock source for this purpose.
|
||||||
|
*/
|
||||||
|
|
||||||
|
//#include "fmacros.h"
|
||||||
|
#include <stdint.h>
|
||||||
|
//#include <unistd.h>
|
||||||
|
|
||||||
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
|
#define inline
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* A counter in micro-seconds. The 'monotime' type is provided for variables
|
||||||
|
* holding a monotonic time. This will help distinguish & document that the
|
||||||
|
* variable is associated with the monotonic clock and should not be confused
|
||||||
|
* with other types of time.*/
|
||||||
|
typedef uint64_t monotime;
|
||||||
|
|
||||||
|
/* Retrieve counter of micro-seconds relative to an arbitrary point in time. */
|
||||||
|
extern monotime (*getMonotonicUs)(void);
|
||||||
|
|
||||||
|
|
||||||
|
/* Call once at startup to initialize the monotonic clock. Though this only
|
||||||
|
* needs to be called once, it may be called additional times without impact.
|
||||||
|
* Returns a printable string indicating the type of clock initialized.
|
||||||
|
* (The returned string is static and doesn't need to be freed.) */
|
||||||
|
const char * monotonicInit();
|
||||||
|
|
||||||
|
|
||||||
|
/* Functions to measure elapsed time. Example:
|
||||||
|
* monotime myTimer;
|
||||||
|
* elapsedStart(&myTimer);
|
||||||
|
* while (elapsedMs(myTimer) < 10) {} // loops for 10ms
|
||||||
|
*/
|
||||||
|
static inline void elapsedStart(monotime *start_time) {
|
||||||
|
*start_time = getMonotonicUs();
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline uint64_t elapsedUs(monotime start_time) {
|
||||||
|
return getMonotonicUs() - start_time;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline uint64_t elapsedMs(monotime start_time) {
|
||||||
|
return elapsedUs(start_time) / 1000;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
|
@ -0,0 +1,173 @@
|
||||||
|
#include "monotonic.h"
|
||||||
|
#include <stddef.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <time.h>
|
||||||
|
|
||||||
|
#undef NDEBUG
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
|
#if defined(_WIN32) || defined(_WIN64)
|
||||||
|
#include "msvcTime.h"
|
||||||
|
#include "msvcStdio.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* The function pointer for clock retrieval. */
|
||||||
|
monotime (*getMonotonicUs)(void) = NULL;
|
||||||
|
|
||||||
|
static char monotonic_info_string[32];
|
||||||
|
|
||||||
|
|
||||||
|
/* Using the processor clock (aka TSC on x86) can provide improved performance
|
||||||
|
* throughout Redis wherever the monotonic clock is used. The processor clock
|
||||||
|
* is significantly faster than calling 'clock_getting' (POSIX). While this is
|
||||||
|
* generally safe on modern systems, this link provides additional information
|
||||||
|
* about use of the x86 TSC: http://oliveryang.net/2015/09/pitfalls-of-TSC-usage
|
||||||
|
*
|
||||||
|
* To use the processor clock, either uncomment this line, or build with
|
||||||
|
* CFLAGS="-DUSE_PROCESSOR_CLOCK"
|
||||||
|
#define USE_PROCESSOR_CLOCK
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#if defined(USE_PROCESSOR_CLOCK) && defined(__x86_64__) && defined(__linux__)
|
||||||
|
#include <regex.h>
|
||||||
|
#include <x86intrin.h>
|
||||||
|
|
||||||
|
static long mono_ticksPerMicrosecond = 0;
|
||||||
|
|
||||||
|
static monotime getMonotonicUs_x86() {
|
||||||
|
return __rdtsc() / mono_ticksPerMicrosecond;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void monotonicInit_x86linux() {
|
||||||
|
const int bufflen = 256;
|
||||||
|
char buf[bufflen];
|
||||||
|
regex_t cpuGhzRegex, constTscRegex;
|
||||||
|
const size_t nmatch = 2;
|
||||||
|
regmatch_t pmatch[nmatch];
|
||||||
|
int constantTsc = 0;
|
||||||
|
int rc;
|
||||||
|
|
||||||
|
/* Determine the number of TSC ticks in a micro-second. This is
|
||||||
|
* a constant value matching the standard speed of the processor.
|
||||||
|
* On modern processors, this speed remains constant even though
|
||||||
|
* the actual clock speed varies dynamically for each core. */
|
||||||
|
rc = regcomp(&cpuGhzRegex, "^model name\\s+:.*@ ([0-9.]+)GHz", REG_EXTENDED);
|
||||||
|
assert(rc == 0);
|
||||||
|
|
||||||
|
/* Also check that the constant_tsc flag is present. (It should be
|
||||||
|
* unless this is a really old CPU. */
|
||||||
|
rc = regcomp(&constTscRegex, "^flags\\s+:.* constant_tsc", REG_EXTENDED);
|
||||||
|
assert(rc == 0);
|
||||||
|
|
||||||
|
FILE *cpuinfo = fopen("/proc/cpuinfo", "r");
|
||||||
|
if (cpuinfo != NULL) {
|
||||||
|
while (fgets(buf, bufflen, cpuinfo) != NULL) {
|
||||||
|
if (regexec(&cpuGhzRegex, buf, nmatch, pmatch, 0) == 0) {
|
||||||
|
buf[pmatch[1].rm_eo] = '\0';
|
||||||
|
double ghz = atof(&buf[pmatch[1].rm_so]);
|
||||||
|
mono_ticksPerMicrosecond = (long)(ghz * 1000);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while (fgets(buf, bufflen, cpuinfo) != NULL) {
|
||||||
|
if (regexec(&constTscRegex, buf, nmatch, pmatch, 0) == 0) {
|
||||||
|
constantTsc = 1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fclose(cpuinfo);
|
||||||
|
}
|
||||||
|
regfree(&cpuGhzRegex);
|
||||||
|
regfree(&constTscRegex);
|
||||||
|
|
||||||
|
if (mono_ticksPerMicrosecond == 0) {
|
||||||
|
fprintf(stderr, "monotonic: x86 linux, unable to determine clock rate");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (!constantTsc) {
|
||||||
|
fprintf(stderr, "monotonic: x86 linux, 'constant_tsc' flag not present");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
snprintf(monotonic_info_string, sizeof(monotonic_info_string),
|
||||||
|
"X86 TSC @ %ld ticks/us", mono_ticksPerMicrosecond);
|
||||||
|
getMonotonicUs = getMonotonicUs_x86;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#if defined(USE_PROCESSOR_CLOCK) && defined(__aarch64__)
|
||||||
|
static long mono_ticksPerMicrosecond = 0;
|
||||||
|
|
||||||
|
/* Read the clock value. */
|
||||||
|
static inline uint64_t __cntvct() {
|
||||||
|
uint64_t virtual_timer_value;
|
||||||
|
__asm__ volatile("mrs %0, cntvct_el0" : "=r"(virtual_timer_value));
|
||||||
|
return virtual_timer_value;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Read the Count-timer Frequency. */
|
||||||
|
static inline uint32_t cntfrq_hz() {
|
||||||
|
uint64_t virtual_freq_value;
|
||||||
|
__asm__ volatile("mrs %0, cntfrq_el0" : "=r"(virtual_freq_value));
|
||||||
|
return (uint32_t)virtual_freq_value; /* top 32 bits are reserved */
|
||||||
|
}
|
||||||
|
|
||||||
|
static monotime getMonotonicUs_aarch64() {
|
||||||
|
return __cntvct() / mono_ticksPerMicrosecond;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void monotonicInit_aarch64() {
|
||||||
|
mono_ticksPerMicrosecond = (long)cntfrq_hz() / 1000L / 1000L;
|
||||||
|
if (mono_ticksPerMicrosecond == 0) {
|
||||||
|
fprintf(stderr, "monotonic: aarch64, unable to determine clock rate");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
snprintf(monotonic_info_string, sizeof(monotonic_info_string),
|
||||||
|
"ARM CNTVCT @ %ld ticks/us", mono_ticksPerMicrosecond);
|
||||||
|
getMonotonicUs = getMonotonicUs_aarch64;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static monotime getMonotonicUs_posix(void) {
|
||||||
|
/* clock_gettime() is specified in POSIX.1b (1993). Even so, some systems
|
||||||
|
* did not support this until much later. CLOCK_MONOTONIC is technically
|
||||||
|
* optional and may not be supported - but it appears to be universal.
|
||||||
|
* If this is not supported, provide a system-specific alternate version. */
|
||||||
|
struct timespec ts;
|
||||||
|
clock_gettime(CLOCK_MONOTONIC, &ts);
|
||||||
|
return ((uint64_t)ts.tv_sec) * 1000000 + ts.tv_nsec / 1000;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void monotonicInit_posix() {
|
||||||
|
/* Ensure that CLOCK_MONOTONIC is supported. This should be supported
|
||||||
|
* on any reasonably current OS. If the assertion below fails, provide
|
||||||
|
* an appropriate alternate implementation. */
|
||||||
|
struct timespec ts;
|
||||||
|
int rc = clock_gettime(CLOCK_MONOTONIC, &ts);
|
||||||
|
assert(rc == 0);
|
||||||
|
|
||||||
|
snprintf(monotonic_info_string, sizeof(monotonic_info_string),
|
||||||
|
"POSIX clock_gettime");
|
||||||
|
getMonotonicUs = getMonotonicUs_posix;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
const char * monotonicInit() {
|
||||||
|
#if defined(USE_PROCESSOR_CLOCK) && defined(__x86_64__) && defined(__linux__)
|
||||||
|
if (getMonotonicUs == NULL) monotonicInit_x86linux();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(USE_PROCESSOR_CLOCK) && defined(__aarch64__)
|
||||||
|
if (getMonotonicUs == NULL) monotonicInit_aarch64();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (getMonotonicUs == NULL) monotonicInit_posix();
|
||||||
|
|
||||||
|
return monotonic_info_string;
|
||||||
|
}
|
|
@ -270,3 +270,9 @@
|
||||||
|
|
||||||
# in retrieve blocking model, only in 50% query threads will be used in query processing in dnode
|
# in retrieve blocking model, only in 50% query threads will be used in query processing in dnode
|
||||||
# retrieveBlockingModel 0
|
# retrieveBlockingModel 0
|
||||||
|
|
||||||
|
# the maximum allowed query buffer size in MB during query processing for each data node
|
||||||
|
# -1 no limit (default)
|
||||||
|
# 0 no query allowed, queries are disabled
|
||||||
|
# queryBufferSize -1
|
||||||
|
|
||||||
|
|
|
@ -47,6 +47,9 @@ cp ${compile_dir}/../packaging/cfg/taos.cfg ${pkg_dir}${install_home_pat
|
||||||
cp ${compile_dir}/../packaging/deb/taosd ${pkg_dir}${install_home_path}/init.d
|
cp ${compile_dir}/../packaging/deb/taosd ${pkg_dir}${install_home_path}/init.d
|
||||||
cp ${compile_dir}/../packaging/tools/post.sh ${pkg_dir}${install_home_path}/script
|
cp ${compile_dir}/../packaging/tools/post.sh ${pkg_dir}${install_home_path}/script
|
||||||
cp ${compile_dir}/../packaging/tools/preun.sh ${pkg_dir}${install_home_path}/script
|
cp ${compile_dir}/../packaging/tools/preun.sh ${pkg_dir}${install_home_path}/script
|
||||||
|
cp ${compile_dir}/../packaging/tools/startPre.sh ${pkg_dir}${install_home_path}/bin
|
||||||
|
cp ${compile_dir}/../packaging/tools/set_core.sh ${pkg_dir}${install_home_path}/bin
|
||||||
|
cp ${compile_dir}/../packaging/tools/taosd-dump-cfg.gdb ${pkg_dir}${install_home_path}/bin
|
||||||
cp ${compile_dir}/build/bin/taosdemo ${pkg_dir}${install_home_path}/bin
|
cp ${compile_dir}/build/bin/taosdemo ${pkg_dir}${install_home_path}/bin
|
||||||
cp ${compile_dir}/build/bin/taosdemox ${pkg_dir}${install_home_path}/bin
|
cp ${compile_dir}/build/bin/taosdemox ${pkg_dir}${install_home_path}/bin
|
||||||
cp ${compile_dir}/build/bin/taosdump ${pkg_dir}${install_home_path}/bin
|
cp ${compile_dir}/build/bin/taosdump ${pkg_dir}${install_home_path}/bin
|
||||||
|
|
|
@ -55,6 +55,9 @@ cp %{_compiledir}/../packaging/cfg/taos.cfg %{buildroot}%{homepath}/cfg
|
||||||
cp %{_compiledir}/../packaging/rpm/taosd %{buildroot}%{homepath}/init.d
|
cp %{_compiledir}/../packaging/rpm/taosd %{buildroot}%{homepath}/init.d
|
||||||
cp %{_compiledir}/../packaging/tools/post.sh %{buildroot}%{homepath}/script
|
cp %{_compiledir}/../packaging/tools/post.sh %{buildroot}%{homepath}/script
|
||||||
cp %{_compiledir}/../packaging/tools/preun.sh %{buildroot}%{homepath}/script
|
cp %{_compiledir}/../packaging/tools/preun.sh %{buildroot}%{homepath}/script
|
||||||
|
cp %{_compiledir}/../packaging/tools/startPre.sh %{buildroot}%{homepath}/bin
|
||||||
|
cp %{_compiledir}/../packaging/tools/set_core.sh %{buildroot}%{homepath}/bin
|
||||||
|
cp %{_compiledir}/../packaging/tools/taosd-dump-cfg.gdb %{buildroot}%{homepath}/bin
|
||||||
cp %{_compiledir}/build/bin/taos %{buildroot}%{homepath}/bin
|
cp %{_compiledir}/build/bin/taos %{buildroot}%{homepath}/bin
|
||||||
cp %{_compiledir}/build/bin/taosd %{buildroot}%{homepath}/bin
|
cp %{_compiledir}/build/bin/taosd %{buildroot}%{homepath}/bin
|
||||||
cp %{_compiledir}/build/bin/taosdemo %{buildroot}%{homepath}/bin
|
cp %{_compiledir}/build/bin/taosdemo %{buildroot}%{homepath}/bin
|
||||||
|
|
|
@ -168,6 +168,7 @@ function install_main_path() {
|
||||||
if [ "$verMode" == "cluster" ]; then
|
if [ "$verMode" == "cluster" ]; then
|
||||||
${csudo} mkdir -p ${nginx_dir}
|
${csudo} mkdir -p ${nginx_dir}
|
||||||
fi
|
fi
|
||||||
|
${csudo} cp ${script_dir}/email ${install_main_dir}/ ||:
|
||||||
}
|
}
|
||||||
|
|
||||||
function install_bin() {
|
function install_bin() {
|
||||||
|
@ -604,9 +605,7 @@ function install_service_on_systemd() {
|
||||||
${csudo} bash -c "echo '[Service]' >> ${taosd_service_config}"
|
${csudo} bash -c "echo '[Service]' >> ${taosd_service_config}"
|
||||||
${csudo} bash -c "echo 'Type=simple' >> ${taosd_service_config}"
|
${csudo} bash -c "echo 'Type=simple' >> ${taosd_service_config}"
|
||||||
${csudo} bash -c "echo 'ExecStart=/usr/bin/taosd' >> ${taosd_service_config}"
|
${csudo} bash -c "echo 'ExecStart=/usr/bin/taosd' >> ${taosd_service_config}"
|
||||||
#${csudo} bash -c "echo 'ExecStartPre=/usr/local/taos/bin/setDelay.sh' >> ${taosd_service_config}"
|
${csudo} bash -c "echo 'ExecStartPre=/usr/local/taos/bin/startPre.sh' >> ${taosd_service_config}"
|
||||||
#${csudo} bash -c "echo 'ExecStartPost=/usr/local/taos/bin/resetDelay.sh' >> ${taosd_service_config}"
|
|
||||||
#${csudo} bash -c "echo 'ExecStopPost=/usr/local/taos/bin/resetDelay.sh' >> ${taosd_service_config}"
|
|
||||||
${csudo} bash -c "echo 'LimitNOFILE=infinity' >> ${taosd_service_config}"
|
${csudo} bash -c "echo 'LimitNOFILE=infinity' >> ${taosd_service_config}"
|
||||||
${csudo} bash -c "echo 'LimitNPROC=infinity' >> ${taosd_service_config}"
|
${csudo} bash -c "echo 'LimitNPROC=infinity' >> ${taosd_service_config}"
|
||||||
${csudo} bash -c "echo 'LimitCORE=infinity' >> ${taosd_service_config}"
|
${csudo} bash -c "echo 'LimitCORE=infinity' >> ${taosd_service_config}"
|
||||||
|
|
|
@ -578,6 +578,7 @@ function install_service_on_systemd() {
|
||||||
${csudo} bash -c "echo '[Service]' >> ${powerd_service_config}"
|
${csudo} bash -c "echo '[Service]' >> ${powerd_service_config}"
|
||||||
${csudo} bash -c "echo 'Type=simple' >> ${powerd_service_config}"
|
${csudo} bash -c "echo 'Type=simple' >> ${powerd_service_config}"
|
||||||
${csudo} bash -c "echo 'ExecStart=/usr/bin/powerd' >> ${powerd_service_config}"
|
${csudo} bash -c "echo 'ExecStart=/usr/bin/powerd' >> ${powerd_service_config}"
|
||||||
|
${csudo} bash -c "echo 'ExecStartPre=/usr/local/power/bin/startPre.sh' >> ${powerd_service_config}"
|
||||||
${csudo} bash -c "echo 'LimitNOFILE=infinity' >> ${powerd_service_config}"
|
${csudo} bash -c "echo 'LimitNOFILE=infinity' >> ${powerd_service_config}"
|
||||||
${csudo} bash -c "echo 'LimitNPROC=infinity' >> ${powerd_service_config}"
|
${csudo} bash -c "echo 'LimitNPROC=infinity' >> ${powerd_service_config}"
|
||||||
${csudo} bash -c "echo 'LimitCORE=infinity' >> ${powerd_service_config}"
|
${csudo} bash -c "echo 'LimitCORE=infinity' >> ${powerd_service_config}"
|
||||||
|
|
|
@ -149,10 +149,12 @@ function install_bin() {
|
||||||
${csudo} rm -f ${bin_link_dir}/rmtaos || :
|
${csudo} rm -f ${bin_link_dir}/rmtaos || :
|
||||||
|
|
||||||
${csudo} cp -r ${binary_dir}/build/bin/* ${install_main_dir}/bin
|
${csudo} cp -r ${binary_dir}/build/bin/* ${install_main_dir}/bin
|
||||||
|
${csudo} cp -r ${script_dir}/taosd-dump-cfg.gdb ${install_main_dir}/bin
|
||||||
|
|
||||||
if [ "$osType" != "Darwin" ]; then
|
if [ "$osType" != "Darwin" ]; then
|
||||||
${csudo} cp -r ${script_dir}/remove.sh ${install_main_dir}/bin
|
${csudo} cp -r ${script_dir}/remove.sh ${install_main_dir}/bin
|
||||||
${csudo} cp -r ${script_dir}/set_core.sh ${install_main_dir}/bin
|
${csudo} cp -r ${script_dir}/set_core.sh ${install_main_dir}/bin
|
||||||
|
${csudo} cp -r ${script_dir}/startPre.sh ${install_main_dir}/bin
|
||||||
else
|
else
|
||||||
${csudo} cp -r ${script_dir}/remove_client.sh ${install_main_dir}/bin
|
${csudo} cp -r ${script_dir}/remove_client.sh ${install_main_dir}/bin
|
||||||
fi
|
fi
|
||||||
|
@ -330,6 +332,7 @@ function install_service_on_systemd() {
|
||||||
${csudo} bash -c "echo '[Service]' >> ${taosd_service_config}"
|
${csudo} bash -c "echo '[Service]' >> ${taosd_service_config}"
|
||||||
${csudo} bash -c "echo 'Type=simple' >> ${taosd_service_config}"
|
${csudo} bash -c "echo 'Type=simple' >> ${taosd_service_config}"
|
||||||
${csudo} bash -c "echo 'ExecStart=/usr/bin/taosd' >> ${taosd_service_config}"
|
${csudo} bash -c "echo 'ExecStart=/usr/bin/taosd' >> ${taosd_service_config}"
|
||||||
|
${csudo} bash -c "echo 'ExecStartPre=/usr/local/taos/bin/startPre.sh' >> ${taosd_service_config}"
|
||||||
${csudo} bash -c "echo 'LimitNOFILE=infinity' >> ${taosd_service_config}"
|
${csudo} bash -c "echo 'LimitNOFILE=infinity' >> ${taosd_service_config}"
|
||||||
${csudo} bash -c "echo 'LimitNPROC=infinity' >> ${taosd_service_config}"
|
${csudo} bash -c "echo 'LimitNPROC=infinity' >> ${taosd_service_config}"
|
||||||
${csudo} bash -c "echo 'LimitCORE=infinity' >> ${taosd_service_config}"
|
${csudo} bash -c "echo 'LimitCORE=infinity' >> ${taosd_service_config}"
|
||||||
|
|
|
@ -45,7 +45,8 @@ if [ "$osType" != "Darwin" ]; then
|
||||||
strip ${build_dir}/bin/taos
|
strip ${build_dir}/bin/taos
|
||||||
bin_files="${build_dir}/bin/taos ${script_dir}/remove_client.sh"
|
bin_files="${build_dir}/bin/taos ${script_dir}/remove_client.sh"
|
||||||
else
|
else
|
||||||
bin_files="${build_dir}/bin/taos ${build_dir}/bin/taosdump ${build_dir}/bin/taosdemo ${build_dir}/bin/taosdemox ${script_dir}/remove_client.sh ${script_dir}/set_core.sh ${script_dir}/get_client.sh"
|
bin_files="${build_dir}/bin/taos ${build_dir}/bin/taosdump ${build_dir}/bin/taosdemo ${build_dir}/bin/taosdemox\
|
||||||
|
${script_dir}/remove_client.sh ${script_dir}/set_core.sh ${script_dir}/get_client.sh ${script_dir}/taosd-dump-cfg.gdb"
|
||||||
fi
|
fi
|
||||||
lib_files="${build_dir}/lib/libtaos.so.${version}"
|
lib_files="${build_dir}/lib/libtaos.so.${version}"
|
||||||
else
|
else
|
||||||
|
|
|
@ -81,6 +81,7 @@ if [ "$osType" != "Darwin" ]; then
|
||||||
cp ${build_dir}/bin/taosdump ${install_dir}/bin/powerdump
|
cp ${build_dir}/bin/taosdump ${install_dir}/bin/powerdump
|
||||||
cp ${script_dir}/set_core.sh ${install_dir}/bin
|
cp ${script_dir}/set_core.sh ${install_dir}/bin
|
||||||
cp ${script_dir}/get_client.sh ${install_dir}/bin
|
cp ${script_dir}/get_client.sh ${install_dir}/bin
|
||||||
|
cp ${script_dir}/taosd-dump-cfg.gdb ${install_dir}/bin
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
cp ${bin_files} ${install_dir}/bin
|
cp ${bin_files} ${install_dir}/bin
|
||||||
|
|
|
@ -36,7 +36,8 @@ if [ "$pagMode" == "lite" ]; then
|
||||||
strip ${build_dir}/bin/taos
|
strip ${build_dir}/bin/taos
|
||||||
bin_files="${build_dir}/bin/taosd ${build_dir}/bin/taos ${script_dir}/remove.sh"
|
bin_files="${build_dir}/bin/taosd ${build_dir}/bin/taos ${script_dir}/remove.sh"
|
||||||
else
|
else
|
||||||
bin_files="${build_dir}/bin/taosd ${build_dir}/bin/taos ${build_dir}/bin/taosdump ${build_dir}/bin/taosdemo ${build_dir}/bin/taosdemox ${build_dir}/bin/tarbitrator ${script_dir}/remove.sh ${script_dir}/set_core.sh ${script_dir}/get_client.sh"
|
bin_files="${build_dir}/bin/taosd ${build_dir}/bin/taos ${build_dir}/bin/taosdump ${build_dir}/bin/taosdemo ${build_dir}/bin/taosdemox ${build_dir}/bin/tarbitrator\
|
||||||
|
${script_dir}/remove.sh ${script_dir}/set_core.sh ${script_dir}/startPre.sh ${script_dir}/taosd-dump-cfg.gdb"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
lib_files="${build_dir}/lib/libtaos.so.${version}"
|
lib_files="${build_dir}/lib/libtaos.so.${version}"
|
||||||
|
|
|
@ -36,7 +36,8 @@ fi
|
||||||
# strip ${build_dir}/bin/taos
|
# strip ${build_dir}/bin/taos
|
||||||
# bin_files="${build_dir}/bin/powerd ${build_dir}/bin/power ${script_dir}/remove_power.sh"
|
# bin_files="${build_dir}/bin/powerd ${build_dir}/bin/power ${script_dir}/remove_power.sh"
|
||||||
#else
|
#else
|
||||||
# bin_files="${build_dir}/bin/powerd ${build_dir}/bin/power ${build_dir}/bin/powerdemo ${build_dir}/bin/tarbitrator ${script_dir}/remove_power.sh ${script_dir}/set_core.sh"
|
# bin_files="${build_dir}/bin/powerd ${build_dir}/bin/power ${build_dir}/bin/powerdemo ${build_dir}/bin/tarbitrator ${script_dir}/remove_power.sh\
|
||||||
|
# ${script_dir}/set_core.sh ${script_dir}/startPre.sh ${script_dir}/taosd-dump-cfg.gdb"
|
||||||
#fi
|
#fi
|
||||||
|
|
||||||
lib_files="${build_dir}/lib/libtaos.so.${version}"
|
lib_files="${build_dir}/lib/libtaos.so.${version}"
|
||||||
|
@ -82,6 +83,8 @@ else
|
||||||
cp ${build_dir}/bin/tarbitrator ${install_dir}/bin
|
cp ${build_dir}/bin/tarbitrator ${install_dir}/bin
|
||||||
cp ${script_dir}/set_core.sh ${install_dir}/bin
|
cp ${script_dir}/set_core.sh ${install_dir}/bin
|
||||||
cp ${script_dir}/get_client.sh ${install_dir}/bin
|
cp ${script_dir}/get_client.sh ${install_dir}/bin
|
||||||
|
cp ${script_dir}/startPre.sh ${install_dir}/bin
|
||||||
|
cp ${script_dir}/taosd-dump-cfg.gdb ${install_dir}/bin
|
||||||
fi
|
fi
|
||||||
chmod a+x ${install_dir}/bin/* || :
|
chmod a+x ${install_dir}/bin/* || :
|
||||||
|
|
||||||
|
|
|
@ -406,6 +406,7 @@ function install_service_on_systemd() {
|
||||||
${csudo} bash -c "echo '[Service]' >> ${taosd_service_config}"
|
${csudo} bash -c "echo '[Service]' >> ${taosd_service_config}"
|
||||||
${csudo} bash -c "echo 'Type=simple' >> ${taosd_service_config}"
|
${csudo} bash -c "echo 'Type=simple' >> ${taosd_service_config}"
|
||||||
${csudo} bash -c "echo 'ExecStart=/usr/bin/taosd' >> ${taosd_service_config}"
|
${csudo} bash -c "echo 'ExecStart=/usr/bin/taosd' >> ${taosd_service_config}"
|
||||||
|
${csudo} bash -c "echo 'ExecStartPre=/usr/local/taos/bin/startPre.sh' >> ${taosd_service_config}"
|
||||||
${csudo} bash -c "echo 'LimitNOFILE=infinity' >> ${taosd_service_config}"
|
${csudo} bash -c "echo 'LimitNOFILE=infinity' >> ${taosd_service_config}"
|
||||||
${csudo} bash -c "echo 'LimitNPROC=infinity' >> ${taosd_service_config}"
|
${csudo} bash -c "echo 'LimitNPROC=infinity' >> ${taosd_service_config}"
|
||||||
${csudo} bash -c "echo 'LimitCORE=infinity' >> ${taosd_service_config}"
|
${csudo} bash -c "echo 'LimitCORE=infinity' >> ${taosd_service_config}"
|
||||||
|
|
|
@ -0,0 +1,50 @@
|
||||||
|
#!/bin/bash
|
||||||
|
#
|
||||||
|
# if enable core dump, set start count to 3, disable core dump, set start count to 20.
|
||||||
|
# set -e
|
||||||
|
# set -x
|
||||||
|
|
||||||
|
taosd=/etc/systemd/system/taosd.service
|
||||||
|
line=`grep StartLimitBurst ${taosd}`
|
||||||
|
num=${line##*=}
|
||||||
|
#echo "burst num: ${num}"
|
||||||
|
|
||||||
|
startSeqFile=/usr/local/taos/.startSeq
|
||||||
|
recordFile=/usr/local/taos/.startRecord
|
||||||
|
|
||||||
|
startSeq=0
|
||||||
|
|
||||||
|
if [[ ! -e ${startSeqFile} ]]; then
|
||||||
|
startSeq=0
|
||||||
|
else
|
||||||
|
startSeq=$(cat ${startSeqFile})
|
||||||
|
fi
|
||||||
|
|
||||||
|
nextSeq=`expr $startSeq + 1`
|
||||||
|
echo "${nextSeq}" > ${startSeqFile}
|
||||||
|
|
||||||
|
curTime=$(date "+%Y-%m-%d %H:%M:%S")
|
||||||
|
echo "startSeq:${startSeq} startPre.sh exec ${curTime}, burstCnt:${num}" >> ${recordFile}
|
||||||
|
|
||||||
|
|
||||||
|
coreFlag=`ulimit -c`
|
||||||
|
echo "coreFlag: ${coreFlag}" >> ${recordFile}
|
||||||
|
|
||||||
|
if [ ${coreFlag} = "0" ];then
|
||||||
|
#echo "core is 0"
|
||||||
|
if [ ${num} != "20" ];then
|
||||||
|
sed -i "s/^.*StartLimitBurst.*$/StartLimitBurst=20/" ${taosd}
|
||||||
|
systemctl daemon-reload
|
||||||
|
echo "modify burst count from ${num} to 20" >> ${recordFile}
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ${coreFlag} = "unlimited" ];then
|
||||||
|
#echo "core is unlimited"
|
||||||
|
if [ ${num} != "3" ];then
|
||||||
|
sed -i "s/^.*StartLimitBurst.*$/StartLimitBurst=3/" ${taosd}
|
||||||
|
systemctl daemon-reload
|
||||||
|
echo "modify burst count from ${num} to 3" >> ${recordFile}
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
|
@ -297,6 +297,11 @@ typedef struct {
|
||||||
struct SLocalMerger *pLocalMerger;
|
struct SLocalMerger *pLocalMerger;
|
||||||
} SSqlRes;
|
} SSqlRes;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
char key[512];
|
||||||
|
void *pDnodeConn;
|
||||||
|
} SRpcObj;
|
||||||
|
|
||||||
typedef struct STscObj {
|
typedef struct STscObj {
|
||||||
void * signature;
|
void * signature;
|
||||||
void * pTimer;
|
void * pTimer;
|
||||||
|
@ -312,8 +317,8 @@ typedef struct STscObj {
|
||||||
int64_t hbrid;
|
int64_t hbrid;
|
||||||
struct SSqlObj * sqlList;
|
struct SSqlObj * sqlList;
|
||||||
struct SSqlStream *streamList;
|
struct SSqlStream *streamList;
|
||||||
SRpcCorEpSet *tscCorMgmtEpSet;
|
SRpcObj *pRpcObj;
|
||||||
void* pDnodeConn;
|
SRpcCorEpSet *tscCorMgmtEpSet;
|
||||||
pthread_mutex_t mutex;
|
pthread_mutex_t mutex;
|
||||||
int32_t numOfObj; // number of sqlObj from this tscObj
|
int32_t numOfObj; // number of sqlObj from this tscObj
|
||||||
} STscObj;
|
} STscObj;
|
||||||
|
@ -390,8 +395,10 @@ typedef struct SSqlStream {
|
||||||
|
|
||||||
void tscSetStreamDestTable(SSqlStream* pStream, const char* dstTable);
|
void tscSetStreamDestTable(SSqlStream* pStream, const char* dstTable);
|
||||||
|
|
||||||
int32_t tscInitRpc(const char *user, const char *secret, void** pDnodeConn);
|
|
||||||
void tscInitMsgsFp();
|
int tscAcquireRpc(const char *key, const char *user, const char *secret,void **pRpcObj);
|
||||||
|
void tscReleaseRpc(void *param);
|
||||||
|
void tscInitMsgsFp();
|
||||||
|
|
||||||
int tsParseSql(SSqlObj *pSql, bool initial);
|
int tsParseSql(SSqlObj *pSql, bool initial);
|
||||||
|
|
||||||
|
|
|
@ -5427,6 +5427,7 @@ int32_t validateColumnName(char* name) {
|
||||||
|
|
||||||
if (token.type == TK_STRING) {
|
if (token.type == TK_STRING) {
|
||||||
strdequote(token.z);
|
strdequote(token.z);
|
||||||
|
strntolower(token.z, token.z, token.n);
|
||||||
token.n = (uint32_t)strtrim(token.z);
|
token.n = (uint32_t)strtrim(token.z);
|
||||||
|
|
||||||
int32_t k = tSQLGetToken(token.z, &token.type);
|
int32_t k = tSQLGetToken(token.z, &token.type);
|
||||||
|
|
|
@ -157,13 +157,16 @@ void tscProcessHeartBeatRsp(void *param, TAOS_RES *tres, int code) {
|
||||||
SRpcEpSet *epSet = &pRsp->epSet;
|
SRpcEpSet *epSet = &pRsp->epSet;
|
||||||
if (epSet->numOfEps > 0) {
|
if (epSet->numOfEps > 0) {
|
||||||
tscEpSetHtons(epSet);
|
tscEpSetHtons(epSet);
|
||||||
if (!tscEpSetIsEqual(&pSql->pTscObj->tscCorMgmtEpSet->epSet, epSet)) {
|
|
||||||
tscTrace("%p updating epset: numOfEps: %d, inUse: %d", pSql, epSet->numOfEps, epSet->inUse);
|
//SRpcCorEpSet *pCorEpSet = pSql->pTscObj->tscCorMgmtEpSet;
|
||||||
for (int8_t i = 0; i < epSet->numOfEps; i++) {
|
//if (!tscEpSetIsEqual(&pCorEpSet->epSet, epSet)) {
|
||||||
tscTrace("endpoint %d: fqdn=%s, port=%d", i, epSet->fqdn[i], epSet->port[i]);
|
// tscTrace("%p updating epset: numOfEps: %d, inUse: %d", pSql, epSet->numOfEps, epSet->inUse);
|
||||||
}
|
// for (int8_t i = 0; i < epSet->numOfEps; i++) {
|
||||||
tscUpdateMgmtEpSet(pSql, epSet);
|
// tscTrace("endpoint %d: fqdn=%s, port=%d", i, epSet->fqdn[i], epSet->port[i]);
|
||||||
}
|
// }
|
||||||
|
//}
|
||||||
|
//concurrency problem, update mgmt epset anyway
|
||||||
|
tscUpdateMgmtEpSet(pSql, epSet);
|
||||||
}
|
}
|
||||||
|
|
||||||
pSql->pTscObj->connId = htonl(pRsp->connId);
|
pSql->pTscObj->connId = htonl(pRsp->connId);
|
||||||
|
@ -270,7 +273,8 @@ int tscSendMsgToServer(SSqlObj *pSql) {
|
||||||
.code = 0
|
.code = 0
|
||||||
};
|
};
|
||||||
|
|
||||||
rpcSendRequest(pObj->pDnodeConn, &pSql->epSet, &rpcMsg, &pSql->rpcRid);
|
|
||||||
|
rpcSendRequest(pObj->pRpcObj->pDnodeConn, &pSql->epSet, &rpcMsg, &pSql->rpcRid);
|
||||||
return TSDB_CODE_SUCCESS;
|
return TSDB_CODE_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -292,8 +296,8 @@ void tscProcessMsgFromServer(SRpcMsg *rpcMsg, SRpcEpSet *pEpSet) {
|
||||||
if (pObj->signature != pObj) {
|
if (pObj->signature != pObj) {
|
||||||
tscDebug("%p DB connection is closed, cmd:%d pObj:%p signature:%p", pSql, pCmd->command, pObj, pObj->signature);
|
tscDebug("%p DB connection is closed, cmd:%d pObj:%p signature:%p", pSql, pCmd->command, pObj, pObj->signature);
|
||||||
|
|
||||||
taosRemoveRef(tscObjRef, pSql->self);
|
taosRemoveRef(tscObjRef, handle);
|
||||||
taosReleaseRef(tscObjRef, pSql->self);
|
taosReleaseRef(tscObjRef, handle);
|
||||||
rpcFreeCont(rpcMsg->pCont);
|
rpcFreeCont(rpcMsg->pCont);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -303,8 +307,8 @@ void tscProcessMsgFromServer(SRpcMsg *rpcMsg, SRpcEpSet *pEpSet) {
|
||||||
tscDebug("%p sqlObj needs to be released or DB connection is closed, cmd:%d type:%d, pObj:%p signature:%p",
|
tscDebug("%p sqlObj needs to be released or DB connection is closed, cmd:%d type:%d, pObj:%p signature:%p",
|
||||||
pSql, pCmd->command, pQueryInfo->type, pObj, pObj->signature);
|
pSql, pCmd->command, pQueryInfo->type, pObj, pObj->signature);
|
||||||
|
|
||||||
taosRemoveRef(tscObjRef, pSql->self);
|
taosRemoveRef(tscObjRef, handle);
|
||||||
taosReleaseRef(tscObjRef, pSql->self);
|
taosReleaseRef(tscObjRef, handle);
|
||||||
rpcFreeCont(rpcMsg->pCont);
|
rpcFreeCont(rpcMsg->pCont);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -350,7 +354,7 @@ void tscProcessMsgFromServer(SRpcMsg *rpcMsg, SRpcEpSet *pEpSet) {
|
||||||
|
|
||||||
// if there is an error occurring, proceed to the following error handling procedure.
|
// if there is an error occurring, proceed to the following error handling procedure.
|
||||||
if (rpcMsg->code == TSDB_CODE_TSC_ACTION_IN_PROGRESS) {
|
if (rpcMsg->code == TSDB_CODE_TSC_ACTION_IN_PROGRESS) {
|
||||||
taosReleaseRef(tscObjRef, pSql->self);
|
taosReleaseRef(tscObjRef, handle);
|
||||||
rpcFreeCont(rpcMsg->pCont);
|
rpcFreeCont(rpcMsg->pCont);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -418,13 +422,15 @@ void tscProcessMsgFromServer(SRpcMsg *rpcMsg, SRpcEpSet *pEpSet) {
|
||||||
(*pSql->fp)(pSql->param, pSql, rpcMsg->code);
|
(*pSql->fp)(pSql->param, pSql, rpcMsg->code);
|
||||||
}
|
}
|
||||||
|
|
||||||
taosReleaseRef(tscObjRef, pSql->self);
|
|
||||||
|
|
||||||
if (shouldFree) { // in case of table-meta/vgrouplist query, automatically free it
|
if (shouldFree) { // in case of table-meta/vgrouplist query, automatically free it
|
||||||
taosRemoveRef(tscObjRef, pSql->self);
|
taosRemoveRef(tscObjRef, handle);
|
||||||
tscDebug("%p sqlObj is automatically freed", pSql);
|
tscDebug("%p sqlObj is automatically freed", pSql);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
taosReleaseRef(tscObjRef, handle);
|
||||||
|
|
||||||
rpcFreeCont(rpcMsg->pCont);
|
rpcFreeCont(rpcMsg->pCont);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -90,9 +90,11 @@ static SSqlObj *taosConnectImpl(const char *ip, const char *user, const char *pa
|
||||||
} else {
|
} else {
|
||||||
if (tscSetMgmtEpSetFromCfg(tsFirst, tsSecond, &corMgmtEpSet) < 0) return NULL;
|
if (tscSetMgmtEpSetFromCfg(tsFirst, tsSecond, &corMgmtEpSet) < 0) return NULL;
|
||||||
}
|
}
|
||||||
|
char rpcKey[512] = {0};
|
||||||
|
snprintf(rpcKey, sizeof(rpcKey), "%s:%s:%s:%d", user, pass, ip, port);
|
||||||
|
|
||||||
void *pDnodeConn = NULL;
|
void *pRpcObj = NULL;
|
||||||
if (tscInitRpc(user, secretEncrypt, &pDnodeConn) != 0) {
|
if (tscAcquireRpc(rpcKey, user, secretEncrypt, &pRpcObj) != 0) {
|
||||||
terrno = TSDB_CODE_RPC_NETWORK_UNAVAIL;
|
terrno = TSDB_CODE_RPC_NETWORK_UNAVAIL;
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -100,23 +102,21 @@ static SSqlObj *taosConnectImpl(const char *ip, const char *user, const char *pa
|
||||||
STscObj *pObj = (STscObj *)calloc(1, sizeof(STscObj));
|
STscObj *pObj = (STscObj *)calloc(1, sizeof(STscObj));
|
||||||
if (NULL == pObj) {
|
if (NULL == pObj) {
|
||||||
terrno = TSDB_CODE_TSC_OUT_OF_MEMORY;
|
terrno = TSDB_CODE_TSC_OUT_OF_MEMORY;
|
||||||
rpcClose(pDnodeConn);
|
tscReleaseRpc(pRpcObj);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
// set up tscObj's mgmtEpSet
|
|
||||||
pObj->tscCorMgmtEpSet = (SRpcCorEpSet *)malloc(sizeof(SRpcCorEpSet));
|
pObj->tscCorMgmtEpSet = malloc(sizeof(SRpcCorEpSet));
|
||||||
if (NULL == pObj->tscCorMgmtEpSet) {
|
if (pObj->tscCorMgmtEpSet == NULL) {
|
||||||
terrno = TSDB_CODE_TSC_OUT_OF_MEMORY;
|
terrno = TSDB_CODE_TSC_OUT_OF_MEMORY;
|
||||||
rpcClose(pDnodeConn);
|
tscReleaseRpc(pRpcObj);
|
||||||
free(pObj->tscCorMgmtEpSet);
|
|
||||||
free(pObj);
|
free(pObj);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
memcpy(pObj->tscCorMgmtEpSet, &corMgmtEpSet, sizeof(SRpcCorEpSet));
|
memcpy(pObj->tscCorMgmtEpSet, &corMgmtEpSet, sizeof(corMgmtEpSet));
|
||||||
|
|
||||||
pObj->signature = pObj;
|
|
||||||
pObj->pDnodeConn = pDnodeConn;
|
|
||||||
|
|
||||||
|
pObj->signature = pObj;
|
||||||
|
pObj->pRpcObj = (SRpcObj *)pRpcObj;
|
||||||
tstrncpy(pObj->user, user, sizeof(pObj->user));
|
tstrncpy(pObj->user, user, sizeof(pObj->user));
|
||||||
secretEncryptLen = MIN(secretEncryptLen, sizeof(pObj->pass));
|
secretEncryptLen = MIN(secretEncryptLen, sizeof(pObj->pass));
|
||||||
memcpy(pObj->pass, secretEncrypt, secretEncryptLen);
|
memcpy(pObj->pass, secretEncrypt, secretEncryptLen);
|
||||||
|
@ -126,8 +126,7 @@ static SSqlObj *taosConnectImpl(const char *ip, const char *user, const char *pa
|
||||||
/* db name is too long */
|
/* db name is too long */
|
||||||
if (len >= TSDB_DB_NAME_LEN) {
|
if (len >= TSDB_DB_NAME_LEN) {
|
||||||
terrno = TSDB_CODE_TSC_INVALID_DB_LENGTH;
|
terrno = TSDB_CODE_TSC_INVALID_DB_LENGTH;
|
||||||
rpcClose(pDnodeConn);
|
tscReleaseRpc(pRpcObj);
|
||||||
free(pObj->tscCorMgmtEpSet);
|
|
||||||
free(pObj);
|
free(pObj);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -144,8 +143,7 @@ static SSqlObj *taosConnectImpl(const char *ip, const char *user, const char *pa
|
||||||
SSqlObj *pSql = (SSqlObj *)calloc(1, sizeof(SSqlObj));
|
SSqlObj *pSql = (SSqlObj *)calloc(1, sizeof(SSqlObj));
|
||||||
if (NULL == pSql) {
|
if (NULL == pSql) {
|
||||||
terrno = TSDB_CODE_TSC_OUT_OF_MEMORY;
|
terrno = TSDB_CODE_TSC_OUT_OF_MEMORY;
|
||||||
rpcClose(pDnodeConn);
|
tscReleaseRpc(pRpcObj);
|
||||||
free(pObj->tscCorMgmtEpSet);
|
|
||||||
free(pObj);
|
free(pObj);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -161,9 +159,8 @@ static SSqlObj *taosConnectImpl(const char *ip, const char *user, const char *pa
|
||||||
|
|
||||||
if (TSDB_CODE_SUCCESS != tscAllocPayload(&pSql->cmd, TSDB_DEFAULT_PAYLOAD_SIZE)) {
|
if (TSDB_CODE_SUCCESS != tscAllocPayload(&pSql->cmd, TSDB_DEFAULT_PAYLOAD_SIZE)) {
|
||||||
terrno = TSDB_CODE_TSC_OUT_OF_MEMORY;
|
terrno = TSDB_CODE_TSC_OUT_OF_MEMORY;
|
||||||
rpcClose(pDnodeConn);
|
tscReleaseRpc(pRpcObj);
|
||||||
free(pSql);
|
free(pSql);
|
||||||
free(pObj->tscCorMgmtEpSet);
|
|
||||||
free(pObj);
|
free(pObj);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -202,7 +199,7 @@ TAOS *taos_connect_internal(const char *ip, const char *user, const char *pass,
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
tscDebug("%p DB connection is opening, dnodeConn:%p", pObj, pObj->pDnodeConn);
|
tscDebug("%p DB connection is opening, rpcObj: %p, dnodeConn:%p", pObj, pObj->pRpcObj, pObj->pRpcObj->pDnodeConn);
|
||||||
taos_free_result(pSql);
|
taos_free_result(pSql);
|
||||||
|
|
||||||
// version compare only requires the first 3 segments of the version string
|
// version compare only requires the first 3 segments of the version string
|
||||||
|
@ -279,7 +276,7 @@ void taos_close(TAOS *taos) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
tscDebug("%p try to free tscObj and close dnodeConn:%p", pObj, pObj->pDnodeConn);
|
tscDebug("%p try to free tscObj", pObj);
|
||||||
if (pObj->signature != pObj) {
|
if (pObj->signature != pObj) {
|
||||||
tscDebug("%p already closed or invalid tscObj", pObj);
|
tscDebug("%p already closed or invalid tscObj", pObj);
|
||||||
return;
|
return;
|
||||||
|
@ -303,7 +300,7 @@ void taos_close(TAOS *taos) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tscDebug("%p all sqlObj are freed, free tscObj and close dnodeConn:%p", pObj, pObj->pDnodeConn);
|
tscDebug("%p all sqlObj are freed, free tscObj", pObj);
|
||||||
taosRemoveRef(tscRefId, pObj->rid);
|
taosRemoveRef(tscRefId, pObj->rid);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -43,41 +43,74 @@ void *tscTmr;
|
||||||
void *tscQhandle;
|
void *tscQhandle;
|
||||||
int32_t tscRefId = -1;
|
int32_t tscRefId = -1;
|
||||||
int32_t tscNumOfObj = 0; // number of sqlObj in current process.
|
int32_t tscNumOfObj = 0; // number of sqlObj in current process.
|
||||||
|
|
||||||
static void *tscCheckDiskUsageTmr;
|
static void *tscCheckDiskUsageTmr;
|
||||||
|
void *tscRpcCache; // cache to keep rpc obj
|
||||||
|
int32_t tscNumOfThreads = 1; // num of rpc threads
|
||||||
|
static pthread_mutex_t rpcObjMutex; // mutex to protect open the rpc obj concurrently
|
||||||
static pthread_once_t tscinit = PTHREAD_ONCE_INIT;
|
static pthread_once_t tscinit = PTHREAD_ONCE_INIT;
|
||||||
|
|
||||||
void tscCheckDiskUsage(void *UNUSED_PARAM(para), void* UNUSED_PARAM(param)) {
|
void tscCheckDiskUsage(void *UNUSED_PARAM(para), void* UNUSED_PARAM(param)) {
|
||||||
taosGetDisk();
|
taosGetDisk();
|
||||||
taosTmrReset(tscCheckDiskUsage, 1000, NULL, tscTmr, &tscCheckDiskUsageTmr);
|
taosTmrReset(tscCheckDiskUsage, 1000, NULL, tscTmr, &tscCheckDiskUsageTmr);
|
||||||
}
|
}
|
||||||
|
void tscFreeRpcObj(void *param) {
|
||||||
|
assert(param);
|
||||||
|
SRpcObj *pRpcObj = (SRpcObj *)(param);
|
||||||
|
tscDebug("free rpcObj:%p and free pDnodeConn: %p", pRpcObj, pRpcObj->pDnodeConn);
|
||||||
|
rpcClose(pRpcObj->pDnodeConn);
|
||||||
|
}
|
||||||
|
|
||||||
int32_t tscInitRpc(const char *user, const char *secretEncrypt, void **pDnodeConn) {
|
void tscReleaseRpc(void *param) {
|
||||||
SRpcInit rpcInit;
|
if (param == NULL) {
|
||||||
|
return;
|
||||||
if (*pDnodeConn == NULL) {
|
|
||||||
memset(&rpcInit, 0, sizeof(rpcInit));
|
|
||||||
rpcInit.localPort = 0;
|
|
||||||
rpcInit.label = "TSC";
|
|
||||||
rpcInit.numOfThreads = 1; // every DB connection has only one thread
|
|
||||||
rpcInit.cfp = tscProcessMsgFromServer;
|
|
||||||
rpcInit.sessions = tsMaxConnections;
|
|
||||||
rpcInit.connType = TAOS_CONN_CLIENT;
|
|
||||||
rpcInit.user = (char *)user;
|
|
||||||
rpcInit.idleTime = 2000;
|
|
||||||
rpcInit.ckey = "key";
|
|
||||||
rpcInit.spi = 1;
|
|
||||||
rpcInit.secret = (char *)secretEncrypt;
|
|
||||||
|
|
||||||
*pDnodeConn = rpcOpen(&rpcInit);
|
|
||||||
if (*pDnodeConn == NULL) {
|
|
||||||
tscError("failed to init connection to TDengine");
|
|
||||||
return -1;
|
|
||||||
} else {
|
|
||||||
tscDebug("dnodeConn:%p is created, user:%s", *pDnodeConn, user);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
pthread_mutex_lock(&rpcObjMutex);
|
||||||
|
taosCacheRelease(tscRpcCache, (void *)¶m, true);
|
||||||
|
pthread_mutex_unlock(&rpcObjMutex);
|
||||||
|
}
|
||||||
|
|
||||||
|
int32_t tscAcquireRpc(const char *key, const char *user, const char *secretEncrypt, void **ppRpcObj) {
|
||||||
|
pthread_mutex_lock(&rpcObjMutex);
|
||||||
|
|
||||||
|
SRpcObj *pRpcObj = (SRpcObj *)taosCacheAcquireByKey(tscRpcCache, key, strlen(key));
|
||||||
|
if (pRpcObj != NULL) {
|
||||||
|
*ppRpcObj = pRpcObj;
|
||||||
|
pthread_mutex_unlock(&rpcObjMutex);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
SRpcInit rpcInit;
|
||||||
|
memset(&rpcInit, 0, sizeof(rpcInit));
|
||||||
|
rpcInit.localPort = 0;
|
||||||
|
rpcInit.label = "TSC";
|
||||||
|
rpcInit.numOfThreads = tscNumOfThreads * 2;
|
||||||
|
rpcInit.cfp = tscProcessMsgFromServer;
|
||||||
|
rpcInit.sessions = tsMaxConnections;
|
||||||
|
rpcInit.connType = TAOS_CONN_CLIENT;
|
||||||
|
rpcInit.user = (char *)user;
|
||||||
|
rpcInit.idleTime = 2000;
|
||||||
|
rpcInit.ckey = "key";
|
||||||
|
rpcInit.spi = 1;
|
||||||
|
rpcInit.secret = (char *)secretEncrypt;
|
||||||
|
|
||||||
|
SRpcObj rpcObj;
|
||||||
|
memset(&rpcObj, 0, sizeof(rpcObj));
|
||||||
|
strncpy(rpcObj.key, key, strlen(key));
|
||||||
|
rpcObj.pDnodeConn = rpcOpen(&rpcInit);
|
||||||
|
if (rpcObj.pDnodeConn == NULL) {
|
||||||
|
pthread_mutex_unlock(&rpcObjMutex);
|
||||||
|
tscError("failed to init connection to TDengine");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
pRpcObj = taosCachePut(tscRpcCache, rpcObj.key, strlen(rpcObj.key), &rpcObj, sizeof(rpcObj), 1000*10);
|
||||||
|
if (pRpcObj == NULL) {
|
||||||
|
rpcClose(rpcObj.pDnodeConn);
|
||||||
|
pthread_mutex_unlock(&rpcObjMutex);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
*ppRpcObj = pRpcObj;
|
||||||
|
pthread_mutex_unlock(&rpcObjMutex);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -118,7 +151,7 @@ void taos_init_imp(void) {
|
||||||
int queueSize = tsMaxConnections*2;
|
int queueSize = tsMaxConnections*2;
|
||||||
|
|
||||||
double factor = (tscEmbedded == 0)? 2.0:4.0;
|
double factor = (tscEmbedded == 0)? 2.0:4.0;
|
||||||
int32_t tscNumOfThreads = (int)(tsNumOfCores * tsNumOfThreadsPerCore / factor);
|
tscNumOfThreads = (int)(tsNumOfCores * tsNumOfThreadsPerCore / factor);
|
||||||
if (tscNumOfThreads < 2) {
|
if (tscNumOfThreads < 2) {
|
||||||
tscNumOfThreads = 2;
|
tscNumOfThreads = 2;
|
||||||
}
|
}
|
||||||
|
@ -140,6 +173,10 @@ void taos_init_imp(void) {
|
||||||
tscTableMetaInfo = taosHashInit(1024, taosGetDefaultHashFunction(TSDB_DATA_TYPE_BINARY), true, HASH_ENTRY_LOCK);
|
tscTableMetaInfo = taosHashInit(1024, taosGetDefaultHashFunction(TSDB_DATA_TYPE_BINARY), true, HASH_ENTRY_LOCK);
|
||||||
tscDebug("TableMeta:%p", tscTableMetaInfo);
|
tscDebug("TableMeta:%p", tscTableMetaInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int refreshTime = 5;
|
||||||
|
tscRpcCache = taosCacheInit(TSDB_DATA_TYPE_BINARY, refreshTime, true, tscFreeRpcObj, "rpcObj");
|
||||||
|
pthread_mutex_init(&rpcObjMutex, NULL);
|
||||||
|
|
||||||
tscRefId = taosOpenRef(200, tscCloseTscObj);
|
tscRefId = taosOpenRef(200, tscCloseTscObj);
|
||||||
|
|
||||||
|
@ -179,11 +216,19 @@ void taos_cleanup(void) {
|
||||||
taosCloseRef(id);
|
taosCloseRef(id);
|
||||||
|
|
||||||
taosCleanupKeywordsTable();
|
taosCleanupKeywordsTable();
|
||||||
taosCloseLog();
|
|
||||||
|
p = tscRpcCache;
|
||||||
|
tscRpcCache = NULL;
|
||||||
|
|
||||||
|
if (p != NULL) {
|
||||||
|
taosCacheCleanup(p);
|
||||||
|
pthread_mutex_destroy(&rpcObjMutex);
|
||||||
|
}
|
||||||
|
|
||||||
if (tscEmbedded == 0) {
|
if (tscEmbedded == 0) {
|
||||||
rpcCleanup();
|
rpcCleanup();
|
||||||
}
|
taosCloseLog();
|
||||||
|
};
|
||||||
|
|
||||||
p = tscTmr;
|
p = tscTmr;
|
||||||
tscTmr = NULL;
|
tscTmr = NULL;
|
||||||
|
|
|
@ -32,6 +32,14 @@
|
||||||
static void freeQueryInfoImpl(SQueryInfo* pQueryInfo);
|
static void freeQueryInfoImpl(SQueryInfo* pQueryInfo);
|
||||||
static void clearAllTableMetaInfo(SQueryInfo* pQueryInfo);
|
static void clearAllTableMetaInfo(SQueryInfo* pQueryInfo);
|
||||||
|
|
||||||
|
static void tscStrToLower(char *str, int32_t n) {
|
||||||
|
if (str == NULL || n <= 0) { return;}
|
||||||
|
for (int32_t i = 0; i < n; i++) {
|
||||||
|
if (str[i] >= 'A' && str[i] <= 'Z') {
|
||||||
|
str[i] -= ('A' - 'a');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
SCond* tsGetSTableQueryCond(STagCond* pTagCond, uint64_t uid) {
|
SCond* tsGetSTableQueryCond(STagCond* pTagCond, uint64_t uid) {
|
||||||
if (pTagCond->pCond == NULL) {
|
if (pTagCond->pCond == NULL) {
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -447,7 +455,6 @@ void tscFreeRegisteredSqlObj(void *pSql) {
|
||||||
|
|
||||||
SSqlObj* p = *(SSqlObj**)pSql;
|
SSqlObj* p = *(SSqlObj**)pSql;
|
||||||
STscObj* pTscObj = p->pTscObj;
|
STscObj* pTscObj = p->pTscObj;
|
||||||
|
|
||||||
assert(RID_VALID(p->self));
|
assert(RID_VALID(p->self));
|
||||||
|
|
||||||
int32_t num = atomic_sub_fetch_32(&pTscObj->numOfObj, 1);
|
int32_t num = atomic_sub_fetch_32(&pTscObj->numOfObj, 1);
|
||||||
|
@ -898,16 +905,10 @@ void tscCloseTscObj(void *param) {
|
||||||
pObj->signature = NULL;
|
pObj->signature = NULL;
|
||||||
taosTmrStopA(&(pObj->pTimer));
|
taosTmrStopA(&(pObj->pTimer));
|
||||||
|
|
||||||
void* p = pObj->pDnodeConn;
|
|
||||||
if (pObj->pDnodeConn != NULL) {
|
|
||||||
rpcClose(pObj->pDnodeConn);
|
|
||||||
pObj->pDnodeConn = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
tfree(pObj->tscCorMgmtEpSet);
|
tfree(pObj->tscCorMgmtEpSet);
|
||||||
|
tscReleaseRpc(pObj->pRpcObj);
|
||||||
pthread_mutex_destroy(&pObj->mutex);
|
pthread_mutex_destroy(&pObj->mutex);
|
||||||
|
|
||||||
tscDebug("%p DB connection is closed, dnodeConn:%p", pObj, p);
|
|
||||||
tfree(pObj);
|
tfree(pObj);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1420,9 +1421,11 @@ int32_t tscValidateName(SStrToken* pToken) {
|
||||||
char* sep = strnchr(pToken->z, TS_PATH_DELIMITER[0], pToken->n, true);
|
char* sep = strnchr(pToken->z, TS_PATH_DELIMITER[0], pToken->n, true);
|
||||||
if (sep == NULL) { // single part
|
if (sep == NULL) { // single part
|
||||||
if (pToken->type == TK_STRING) {
|
if (pToken->type == TK_STRING) {
|
||||||
|
|
||||||
strdequote(pToken->z);
|
strdequote(pToken->z);
|
||||||
|
tscStrToLower(pToken->z, pToken->n);
|
||||||
pToken->n = (uint32_t)strtrim(pToken->z);
|
pToken->n = (uint32_t)strtrim(pToken->z);
|
||||||
|
|
||||||
int len = tSQLGetToken(pToken->z, &pToken->type);
|
int len = tSQLGetToken(pToken->z, &pToken->type);
|
||||||
|
|
||||||
// single token, validate it
|
// single token, validate it
|
||||||
|
@ -1474,7 +1477,7 @@ int32_t tscValidateName(SStrToken* pToken) {
|
||||||
if (pToken->type == TK_STRING && validateQuoteToken(pToken) != TSDB_CODE_SUCCESS) {
|
if (pToken->type == TK_STRING && validateQuoteToken(pToken) != TSDB_CODE_SUCCESS) {
|
||||||
return TSDB_CODE_TSC_INVALID_SQL;
|
return TSDB_CODE_TSC_INVALID_SQL;
|
||||||
}
|
}
|
||||||
|
|
||||||
// re-build the whole name string
|
// re-build the whole name string
|
||||||
if (pStr[firstPartLen] == TS_PATH_DELIMITER[0]) {
|
if (pStr[firstPartLen] == TS_PATH_DELIMITER[0]) {
|
||||||
// first part do not have quote do nothing
|
// first part do not have quote do nothing
|
||||||
|
@ -1486,6 +1489,8 @@ int32_t tscValidateName(SStrToken* pToken) {
|
||||||
}
|
}
|
||||||
pToken->n += (firstPartLen + sizeof(TS_PATH_DELIMITER[0]));
|
pToken->n += (firstPartLen + sizeof(TS_PATH_DELIMITER[0]));
|
||||||
pToken->z = pStr;
|
pToken->z = pStr;
|
||||||
|
|
||||||
|
tscStrToLower(pToken->z,pToken->n);
|
||||||
}
|
}
|
||||||
|
|
||||||
return TSDB_CODE_SUCCESS;
|
return TSDB_CODE_SUCCESS;
|
||||||
|
|
|
@ -57,7 +57,8 @@ extern int32_t tsCompressMsgSize;
|
||||||
extern char tsTempDir[];
|
extern char tsTempDir[];
|
||||||
|
|
||||||
//query buffer management
|
//query buffer management
|
||||||
extern int32_t tsQueryBufferSize; // maximum allowed usage buffer for each data node during query processing
|
extern int32_t tsQueryBufferSize; // maximum allowed usage buffer size in MB for each data node during query processing
|
||||||
|
extern int64_t tsQueryBufferSizeBytes; // maximum allowed usage buffer size in byte for each data node during query processing
|
||||||
extern int32_t tsRetrieveBlockingModel;// retrieve threads will be blocked
|
extern int32_t tsRetrieveBlockingModel;// retrieve threads will be blocked
|
||||||
|
|
||||||
extern int8_t tsKeepOriginalColumnName;
|
extern int8_t tsKeepOriginalColumnName;
|
||||||
|
|
|
@ -105,6 +105,7 @@ int64_t tsMaxRetentWindow = 24 * 3600L; // maximum time window tolerance
|
||||||
// 0 no query allowed, queries are disabled
|
// 0 no query allowed, queries are disabled
|
||||||
// positive value (in MB)
|
// positive value (in MB)
|
||||||
int32_t tsQueryBufferSize = -1;
|
int32_t tsQueryBufferSize = -1;
|
||||||
|
int64_t tsQueryBufferSizeBytes = -1;
|
||||||
|
|
||||||
// in retrieve blocking model, the retrieve threads will wait for the completion of the query processing.
|
// in retrieve blocking model, the retrieve threads will wait for the completion of the query processing.
|
||||||
int32_t tsRetrieveBlockingModel = 0;
|
int32_t tsRetrieveBlockingModel = 0;
|
||||||
|
@ -283,7 +284,7 @@ bool taosCfgDynamicOptions(char *msg) {
|
||||||
int32_t cfgLen = (int32_t)strlen(cfg->option);
|
int32_t cfgLen = (int32_t)strlen(cfg->option);
|
||||||
if (cfgLen != olen) continue;
|
if (cfgLen != olen) continue;
|
||||||
if (strncasecmp(option, cfg->option, olen) != 0) continue;
|
if (strncasecmp(option, cfg->option, olen) != 0) continue;
|
||||||
if (cfg->valType != TAOS_CFG_VTYPE_INT32) {
|
if (cfg->valType == TAOS_CFG_VTYPE_INT32) {
|
||||||
*((int32_t *)cfg->ptr) = vint;
|
*((int32_t *)cfg->ptr) = vint;
|
||||||
} else {
|
} else {
|
||||||
*((int8_t *)cfg->ptr) = (int8_t)vint;
|
*((int8_t *)cfg->ptr) = (int8_t)vint;
|
||||||
|
@ -1488,6 +1489,10 @@ int32_t taosCheckGlobalCfg() {
|
||||||
tsSyncPort = tsServerPort + TSDB_PORT_SYNC;
|
tsSyncPort = tsServerPort + TSDB_PORT_SYNC;
|
||||||
tsHttpPort = tsServerPort + TSDB_PORT_HTTP;
|
tsHttpPort = tsServerPort + TSDB_PORT_HTTP;
|
||||||
|
|
||||||
|
if (tsQueryBufferSize >= 0) {
|
||||||
|
tsQueryBufferSizeBytes = tsQueryBufferSize * 1048576UL;
|
||||||
|
}
|
||||||
|
|
||||||
taosPrintGlobalCfg();
|
taosPrintGlobalCfg();
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -632,7 +632,7 @@ int32_t tStrToInteger(const char* z, int16_t type, int32_t n, int64_t* value, bo
|
||||||
}
|
}
|
||||||
|
|
||||||
// the string may be overflow according to errno
|
// the string may be overflow according to errno
|
||||||
*value = issigned? strtoll(z, &endPtr, radix):strtoul(z, &endPtr, radix);
|
*value = issigned? strtoll(z, &endPtr, radix):strtoull(z, &endPtr, radix);
|
||||||
|
|
||||||
// not a valid integer number, return error
|
// not a valid integer number, return error
|
||||||
if (endPtr - z != n || errno == ERANGE) {
|
if (endPtr - z != n || errno == ERANGE) {
|
||||||
|
|
|
@ -50,10 +50,13 @@ typedef struct {
|
||||||
void *dbConn;
|
void *dbConn;
|
||||||
void *tmrCtrl;
|
void *tmrCtrl;
|
||||||
pthread_mutex_t mutex;
|
pthread_mutex_t mutex;
|
||||||
|
int32_t delete;
|
||||||
|
int32_t cqObjNum;
|
||||||
} SCqContext;
|
} SCqContext;
|
||||||
|
|
||||||
typedef struct SCqObj {
|
typedef struct SCqObj {
|
||||||
tmr_h tmrId;
|
tmr_h tmrId;
|
||||||
|
int64_t rid;
|
||||||
uint64_t uid;
|
uint64_t uid;
|
||||||
int32_t tid; // table ID
|
int32_t tid; // table ID
|
||||||
int32_t rowSize; // bytes of a row
|
int32_t rowSize; // bytes of a row
|
||||||
|
@ -69,6 +72,84 @@ typedef struct SCqObj {
|
||||||
static void cqProcessStreamRes(void *param, TAOS_RES *tres, TAOS_ROW row);
|
static void cqProcessStreamRes(void *param, TAOS_RES *tres, TAOS_ROW row);
|
||||||
static void cqCreateStream(SCqContext *pContext, SCqObj *pObj);
|
static void cqCreateStream(SCqContext *pContext, SCqObj *pObj);
|
||||||
|
|
||||||
|
int32_t cqObjRef = -1;
|
||||||
|
|
||||||
|
void cqRmFromList(SCqObj *pObj) {
|
||||||
|
//LOCK in caller
|
||||||
|
|
||||||
|
SCqContext *pContext = pObj->pContext;
|
||||||
|
|
||||||
|
if (pObj->prev) {
|
||||||
|
pObj->prev->next = pObj->next;
|
||||||
|
} else {
|
||||||
|
pContext->pHead = pObj->next;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pObj->next) {
|
||||||
|
pObj->next->prev = pObj->prev;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void cqFree(void *handle) {
|
||||||
|
if (tsEnableStream == 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SCqObj *pObj = handle;
|
||||||
|
SCqContext *pContext = pObj->pContext;
|
||||||
|
int32_t delete = 0;
|
||||||
|
|
||||||
|
pthread_mutex_lock(&pContext->mutex);
|
||||||
|
|
||||||
|
// free the resources associated
|
||||||
|
if (pObj->pStream) {
|
||||||
|
taos_close_stream(pObj->pStream);
|
||||||
|
pObj->pStream = NULL;
|
||||||
|
} else {
|
||||||
|
taosTmrStop(pObj->tmrId);
|
||||||
|
pObj->tmrId = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
cInfo("vgId:%d, id:%d CQ:%s is dropped", pContext->vgId, pObj->tid, pObj->sqlStr);
|
||||||
|
tdFreeSchema(pObj->pSchema);
|
||||||
|
free(pObj->dstTable);
|
||||||
|
free(pObj->sqlStr);
|
||||||
|
free(pObj);
|
||||||
|
|
||||||
|
pContext->cqObjNum--;
|
||||||
|
|
||||||
|
if (pContext->cqObjNum <= 0 && pContext->delete) {
|
||||||
|
delete = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
pthread_mutex_unlock(&pContext->mutex);
|
||||||
|
|
||||||
|
if (delete) {
|
||||||
|
pthread_mutex_unlock(&pContext->mutex);
|
||||||
|
|
||||||
|
pthread_mutex_destroy(&pContext->mutex);
|
||||||
|
|
||||||
|
taosTmrCleanUp(pContext->tmrCtrl);
|
||||||
|
pContext->tmrCtrl = NULL;
|
||||||
|
|
||||||
|
cDebug("vgId:%d, CQ is closed", pContext->vgId);
|
||||||
|
free(pContext);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void cqCreateRef() {
|
||||||
|
int32_t ref = atomic_load_32(&cqObjRef);
|
||||||
|
if (ref == -1) {
|
||||||
|
ref = taosOpenRef(4096, cqFree);
|
||||||
|
|
||||||
|
if (atomic_val_compare_exchange_32(&cqObjRef, -1, ref) != -1) {
|
||||||
|
taosCloseRef(ref);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void *cqOpen(void *ahandle, const SCqCfg *pCfg) {
|
void *cqOpen(void *ahandle, const SCqCfg *pCfg) {
|
||||||
if (tsEnableStream == 0) {
|
if (tsEnableStream == 0) {
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -79,6 +160,8 @@ void *cqOpen(void *ahandle, const SCqCfg *pCfg) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cqCreateRef();
|
||||||
|
|
||||||
pContext->tmrCtrl = taosTmrInit(0, 0, 0, "CQ");
|
pContext->tmrCtrl = taosTmrInit(0, 0, 0, "CQ");
|
||||||
|
|
||||||
tstrncpy(pContext->user, pCfg->user, sizeof(pContext->user));
|
tstrncpy(pContext->user, pCfg->user, sizeof(pContext->user));
|
||||||
|
@ -97,6 +180,7 @@ void *cqOpen(void *ahandle, const SCqCfg *pCfg) {
|
||||||
|
|
||||||
pthread_mutex_init(&pContext->mutex, NULL);
|
pthread_mutex_init(&pContext->mutex, NULL);
|
||||||
|
|
||||||
|
|
||||||
cDebug("vgId:%d, CQ is opened", pContext->vgId);
|
cDebug("vgId:%d, CQ is opened", pContext->vgId);
|
||||||
|
|
||||||
return pContext;
|
return pContext;
|
||||||
|
@ -109,30 +193,30 @@ void cqClose(void *handle) {
|
||||||
SCqContext *pContext = handle;
|
SCqContext *pContext = handle;
|
||||||
if (handle == NULL) return;
|
if (handle == NULL) return;
|
||||||
|
|
||||||
|
pContext->delete = 1;
|
||||||
|
|
||||||
// stop all CQs
|
// stop all CQs
|
||||||
cqStop(pContext);
|
cqStop(pContext);
|
||||||
|
|
||||||
// free all resources
|
int64_t rid = 0;
|
||||||
pthread_mutex_lock(&pContext->mutex);
|
|
||||||
|
|
||||||
SCqObj *pObj = pContext->pHead;
|
while (1) {
|
||||||
while (pObj) {
|
pthread_mutex_lock(&pContext->mutex);
|
||||||
SCqObj *pTemp = pObj;
|
|
||||||
pObj = pObj->next;
|
|
||||||
tdFreeSchema(pTemp->pSchema);
|
|
||||||
tfree(pTemp->sqlStr);
|
|
||||||
free(pTemp);
|
|
||||||
}
|
|
||||||
|
|
||||||
pthread_mutex_unlock(&pContext->mutex);
|
|
||||||
|
|
||||||
pthread_mutex_destroy(&pContext->mutex);
|
SCqObj *pObj = pContext->pHead;
|
||||||
|
if (pObj) {
|
||||||
|
cqRmFromList(pObj);
|
||||||
|
|
||||||
taosTmrCleanUp(pContext->tmrCtrl);
|
rid = pObj->rid;
|
||||||
pContext->tmrCtrl = NULL;
|
} else {
|
||||||
|
pthread_mutex_unlock(&pContext->mutex);
|
||||||
cDebug("vgId:%d, CQ is closed", pContext->vgId);
|
break;
|
||||||
free(pContext);
|
}
|
||||||
|
|
||||||
|
pthread_mutex_unlock(&pContext->mutex);
|
||||||
|
|
||||||
|
taosRemoveRef(cqObjRef, rid);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void cqStart(void *handle) {
|
void cqStart(void *handle) {
|
||||||
|
@ -191,7 +275,8 @@ void *cqCreate(void *handle, uint64_t uid, int32_t sid, const char* dstTable, ch
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
SCqContext *pContext = handle;
|
SCqContext *pContext = handle;
|
||||||
|
int64_t rid = 0;
|
||||||
|
|
||||||
SCqObj *pObj = calloc(sizeof(SCqObj), 1);
|
SCqObj *pObj = calloc(sizeof(SCqObj), 1);
|
||||||
if (pObj == NULL) return NULL;
|
if (pObj == NULL) return NULL;
|
||||||
|
|
||||||
|
@ -213,32 +298,36 @@ void *cqCreate(void *handle, uint64_t uid, int32_t sid, const char* dstTable, ch
|
||||||
if (pContext->pHead) pContext->pHead->prev = pObj;
|
if (pContext->pHead) pContext->pHead->prev = pObj;
|
||||||
pContext->pHead = pObj;
|
pContext->pHead = pObj;
|
||||||
|
|
||||||
|
pContext->cqObjNum++;
|
||||||
|
|
||||||
|
pObj->rid = taosAddRef(cqObjRef, pObj);
|
||||||
|
|
||||||
cqCreateStream(pContext, pObj);
|
cqCreateStream(pContext, pObj);
|
||||||
|
|
||||||
|
rid = pObj->rid;
|
||||||
|
|
||||||
pthread_mutex_unlock(&pContext->mutex);
|
pthread_mutex_unlock(&pContext->mutex);
|
||||||
|
|
||||||
return pObj;
|
|
||||||
|
return (void *)rid;
|
||||||
}
|
}
|
||||||
|
|
||||||
void cqDrop(void *handle) {
|
void cqDrop(void *handle) {
|
||||||
if (tsEnableStream == 0) {
|
if (tsEnableStream == 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
SCqObj *pObj = handle;
|
|
||||||
SCqContext *pContext = pObj->pContext;
|
|
||||||
|
|
||||||
|
SCqObj* pObj = (SCqObj*)taosAcquireRef(cqObjRef, (int64_t)handle);
|
||||||
|
if (pObj == NULL) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
SCqContext *pContext = pObj->pContext;
|
||||||
|
|
||||||
pthread_mutex_lock(&pContext->mutex);
|
pthread_mutex_lock(&pContext->mutex);
|
||||||
|
|
||||||
if (pObj->prev) {
|
cqRmFromList(pObj);
|
||||||
pObj->prev->next = pObj->next;
|
|
||||||
} else {
|
|
||||||
pContext->pHead = pObj->next;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (pObj->next) {
|
|
||||||
pObj->next->prev = pObj->prev;
|
|
||||||
}
|
|
||||||
|
|
||||||
// free the resources associated
|
// free the resources associated
|
||||||
if (pObj->pStream) {
|
if (pObj->pStream) {
|
||||||
taos_close_stream(pObj->pStream);
|
taos_close_stream(pObj->pStream);
|
||||||
|
@ -248,17 +337,18 @@ void cqDrop(void *handle) {
|
||||||
pObj->tmrId = 0;
|
pObj->tmrId = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
cInfo("vgId:%d, id:%d CQ:%s is dropped", pContext->vgId, pObj->tid, pObj->sqlStr);
|
|
||||||
tdFreeSchema(pObj->pSchema);
|
|
||||||
free(pObj->dstTable);
|
|
||||||
free(pObj->sqlStr);
|
|
||||||
free(pObj);
|
|
||||||
|
|
||||||
pthread_mutex_unlock(&pContext->mutex);
|
pthread_mutex_unlock(&pContext->mutex);
|
||||||
|
|
||||||
|
taosRemoveRef(cqObjRef, (int64_t)handle);
|
||||||
|
taosReleaseRef(cqObjRef, (int64_t)handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void doCreateStream(void *param, TAOS_RES *result, int32_t code) {
|
static void doCreateStream(void *param, TAOS_RES *result, int32_t code) {
|
||||||
SCqObj* pObj = (SCqObj*)param;
|
SCqObj* pObj = (SCqObj*)taosAcquireRef(cqObjRef, (int64_t)param);
|
||||||
|
if (pObj == NULL) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
SCqContext* pContext = pObj->pContext;
|
SCqContext* pContext = pObj->pContext;
|
||||||
SSqlObj* pSql = (SSqlObj*)result;
|
SSqlObj* pSql = (SSqlObj*)result;
|
||||||
if (atomic_val_compare_exchange_ptr(&(pContext->dbConn), NULL, pSql->pTscObj) != NULL) {
|
if (atomic_val_compare_exchange_ptr(&(pContext->dbConn), NULL, pSql->pTscObj) != NULL) {
|
||||||
|
@ -267,10 +357,16 @@ static void doCreateStream(void *param, TAOS_RES *result, int32_t code) {
|
||||||
pthread_mutex_lock(&pContext->mutex);
|
pthread_mutex_lock(&pContext->mutex);
|
||||||
cqCreateStream(pContext, pObj);
|
cqCreateStream(pContext, pObj);
|
||||||
pthread_mutex_unlock(&pContext->mutex);
|
pthread_mutex_unlock(&pContext->mutex);
|
||||||
|
|
||||||
|
taosReleaseRef(cqObjRef, (int64_t)param);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void cqProcessCreateTimer(void *param, void *tmrId) {
|
static void cqProcessCreateTimer(void *param, void *tmrId) {
|
||||||
SCqObj* pObj = (SCqObj*)param;
|
SCqObj* pObj = (SCqObj*)taosAcquireRef(cqObjRef, (int64_t)param);
|
||||||
|
if (pObj == NULL) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
SCqContext* pContext = pObj->pContext;
|
SCqContext* pContext = pObj->pContext;
|
||||||
|
|
||||||
if (pContext->dbConn == NULL) {
|
if (pContext->dbConn == NULL) {
|
||||||
|
@ -281,6 +377,8 @@ static void cqProcessCreateTimer(void *param, void *tmrId) {
|
||||||
cqCreateStream(pContext, pObj);
|
cqCreateStream(pContext, pObj);
|
||||||
pthread_mutex_unlock(&pContext->mutex);
|
pthread_mutex_unlock(&pContext->mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
taosReleaseRef(cqObjRef, (int64_t)param);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void cqCreateStream(SCqContext *pContext, SCqObj *pObj) {
|
static void cqCreateStream(SCqContext *pContext, SCqObj *pObj) {
|
||||||
|
@ -288,13 +386,13 @@ static void cqCreateStream(SCqContext *pContext, SCqObj *pObj) {
|
||||||
|
|
||||||
if (pContext->dbConn == NULL) {
|
if (pContext->dbConn == NULL) {
|
||||||
cDebug("vgId:%d, create dbConn after 1000 ms", pContext->vgId);
|
cDebug("vgId:%d, create dbConn after 1000 ms", pContext->vgId);
|
||||||
pObj->tmrId = taosTmrStart(cqProcessCreateTimer, 1000, pObj, pContext->tmrCtrl);
|
pObj->tmrId = taosTmrStart(cqProcessCreateTimer, 1000, (void *)pObj->rid, pContext->tmrCtrl);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
pObj->tmrId = 0;
|
pObj->tmrId = 0;
|
||||||
|
|
||||||
if (pObj->pStream == NULL) {
|
if (pObj->pStream == NULL) {
|
||||||
pObj->pStream = taos_open_stream(pContext->dbConn, pObj->sqlStr, cqProcessStreamRes, 0, pObj, NULL);
|
pObj->pStream = taos_open_stream(pContext->dbConn, pObj->sqlStr, cqProcessStreamRes, 0, (void *)pObj->rid, NULL);
|
||||||
|
|
||||||
// TODO the pObj->pStream may be released if error happens
|
// TODO the pObj->pStream may be released if error happens
|
||||||
if (pObj->pStream) {
|
if (pObj->pStream) {
|
||||||
|
@ -308,18 +406,28 @@ static void cqCreateStream(SCqContext *pContext, SCqObj *pObj) {
|
||||||
}
|
}
|
||||||
|
|
||||||
static void cqProcessStreamRes(void *param, TAOS_RES *tres, TAOS_ROW row) {
|
static void cqProcessStreamRes(void *param, TAOS_RES *tres, TAOS_ROW row) {
|
||||||
SCqObj *pObj = (SCqObj *)param;
|
SCqObj* pObj = (SCqObj*)taosAcquireRef(cqObjRef, (int64_t)param);
|
||||||
|
if (pObj == NULL) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (tres == NULL && row == NULL) {
|
if (tres == NULL && row == NULL) {
|
||||||
taos_close_stream(pObj->pStream);
|
taos_close_stream(pObj->pStream);
|
||||||
|
|
||||||
pObj->pStream = NULL;
|
pObj->pStream = NULL;
|
||||||
|
|
||||||
|
taosReleaseRef(cqObjRef, (int64_t)param);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
SCqContext *pContext = pObj->pContext;
|
SCqContext *pContext = pObj->pContext;
|
||||||
STSchema *pSchema = pObj->pSchema;
|
STSchema *pSchema = pObj->pSchema;
|
||||||
if (pObj->pStream == NULL) return;
|
if (pObj->pStream == NULL) {
|
||||||
|
taosReleaseRef(cqObjRef, (int64_t)param);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
cDebug("vgId:%d, id:%d CQ:%s stream result is ready", pContext->vgId, pObj->tid, pObj->sqlStr);
|
cDebug("vgId:%d, id:%d CQ:%s stream result is ready", pContext->vgId, pObj->tid, pObj->sqlStr);
|
||||||
|
|
||||||
int32_t size = sizeof(SWalHead) + sizeof(SSubmitMsg) + sizeof(SSubmitBlk) + TD_DATA_ROW_HEAD_SIZE + pObj->rowSize;
|
int32_t size = sizeof(SWalHead) + sizeof(SSubmitMsg) + sizeof(SSubmitBlk) + TD_DATA_ROW_HEAD_SIZE + pObj->rowSize;
|
||||||
|
@ -370,5 +478,7 @@ static void cqProcessStreamRes(void *param, TAOS_RES *tres, TAOS_ROW row) {
|
||||||
// write into vnode write queue
|
// write into vnode write queue
|
||||||
pContext->cqWrite(pContext->vgId, pHead, TAOS_QTYPE_CQ, NULL);
|
pContext->cqWrite(pContext->vgId, pHead, TAOS_QTYPE_CQ, NULL);
|
||||||
free(buffer);
|
free(buffer);
|
||||||
|
|
||||||
|
taosReleaseRef(cqObjRef, (int64_t)param);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -156,7 +156,7 @@ static int32_t dnodeWriteCfg() {
|
||||||
len += snprintf(content + len, maxLen - len, "}\n");
|
len += snprintf(content + len, maxLen - len, "}\n");
|
||||||
|
|
||||||
fwrite(content, 1, len, fp);
|
fwrite(content, 1, len, fp);
|
||||||
fflush(fp);
|
fsync(fileno(fp));
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
free(content);
|
free(content);
|
||||||
terrno = 0;
|
terrno = 0;
|
||||||
|
|
|
@ -277,7 +277,7 @@ static int32_t dnodeWriteEps() {
|
||||||
len += snprintf(content + len, maxLen - len, "}\n");
|
len += snprintf(content + len, maxLen - len, "}\n");
|
||||||
|
|
||||||
fwrite(content, 1, len, fp);
|
fwrite(content, 1, len, fp);
|
||||||
fflush(fp);
|
fsync(fileno(fp));
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
free(content);
|
free(content);
|
||||||
terrno = 0;
|
terrno = 0;
|
||||||
|
|
|
@ -286,7 +286,7 @@ static int32_t dnodeWriteMInfos() {
|
||||||
len += snprintf(content + len, maxLen - len, "}\n");
|
len += snprintf(content + len, maxLen - len, "}\n");
|
||||||
|
|
||||||
fwrite(content, 1, len, fp);
|
fwrite(content, 1, len, fp);
|
||||||
fflush(fp);
|
fsync(fileno(fp));
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
free(content);
|
free(content);
|
||||||
terrno = 0;
|
terrno = 0;
|
||||||
|
|
|
@ -123,7 +123,7 @@ static void mnodePrintUserAuth() {
|
||||||
mnodeDecUserRef(pUser);
|
mnodeDecUserRef(pUser);
|
||||||
}
|
}
|
||||||
|
|
||||||
fflush(fp);
|
fsync(fileno(fp));
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -18,6 +18,9 @@
|
||||||
#include "tconfig.h"
|
#include "tconfig.h"
|
||||||
#include "tglobal.h"
|
#include "tglobal.h"
|
||||||
#include "tulog.h"
|
#include "tulog.h"
|
||||||
|
#include <errno.h>
|
||||||
|
#include <libproc.h>
|
||||||
|
|
||||||
|
|
||||||
static void taosGetSystemTimezone() {
|
static void taosGetSystemTimezone() {
|
||||||
// get and set default timezone
|
// get and set default timezone
|
||||||
|
@ -103,8 +106,18 @@ int taosSystem(const char *cmd) {
|
||||||
|
|
||||||
void taosSetCoreDump() {}
|
void taosSetCoreDump() {}
|
||||||
|
|
||||||
|
char cmdline[1024];
|
||||||
|
|
||||||
char *taosGetCmdlineByPID(int pid) {
|
char *taosGetCmdlineByPID(int pid) {
|
||||||
return "[not supported yet]";
|
|
||||||
|
errno = 0;
|
||||||
|
|
||||||
|
if (proc_pidpath(pid, cmdline, sizeof(cmdline)) <= 0) {
|
||||||
|
fprintf(stderr, "PID is %d, %s", pid, strerror(errno));
|
||||||
|
return strerror(errno);
|
||||||
|
}
|
||||||
|
|
||||||
|
return cmdline;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool taosGetSystemUid(char *uid) {
|
bool taosGetSystemUid(char *uid) {
|
||||||
|
|
|
@ -7730,15 +7730,15 @@ static int64_t getQuerySupportBufSize(size_t numOfTables) {
|
||||||
|
|
||||||
int32_t checkForQueryBuf(size_t numOfTables) {
|
int32_t checkForQueryBuf(size_t numOfTables) {
|
||||||
int64_t t = getQuerySupportBufSize(numOfTables);
|
int64_t t = getQuerySupportBufSize(numOfTables);
|
||||||
if (tsQueryBufferSize < 0) {
|
if (tsQueryBufferSizeBytes < 0) {
|
||||||
return TSDB_CODE_SUCCESS;
|
return TSDB_CODE_SUCCESS;
|
||||||
} else if (tsQueryBufferSize > 0) {
|
} else if (tsQueryBufferSizeBytes > 0) {
|
||||||
|
|
||||||
while(1) {
|
while(1) {
|
||||||
int64_t s = tsQueryBufferSize;
|
int64_t s = tsQueryBufferSizeBytes;
|
||||||
int64_t remain = s - t;
|
int64_t remain = s - t;
|
||||||
if (remain >= 0) {
|
if (remain >= 0) {
|
||||||
if (atomic_val_compare_exchange_64(&tsQueryBufferSize, s, remain) == s) {
|
if (atomic_val_compare_exchange_64(&tsQueryBufferSizeBytes, s, remain) == s) {
|
||||||
return TSDB_CODE_SUCCESS;
|
return TSDB_CODE_SUCCESS;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -7752,14 +7752,14 @@ int32_t checkForQueryBuf(size_t numOfTables) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void releaseQueryBuf(size_t numOfTables) {
|
void releaseQueryBuf(size_t numOfTables) {
|
||||||
if (tsQueryBufferSize <= 0) {
|
if (tsQueryBufferSizeBytes < 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
int64_t t = getQuerySupportBufSize(numOfTables);
|
int64_t t = getQuerySupportBufSize(numOfTables);
|
||||||
|
|
||||||
// restore value is not enough buffer available
|
// restore value is not enough buffer available
|
||||||
atomic_add_fetch_64(&tsQueryBufferSize, t);
|
atomic_add_fetch_64(&tsQueryBufferSizeBytes, t);
|
||||||
}
|
}
|
||||||
|
|
||||||
void* qGetResultRetrieveMsg(qinfo_t qinfo) {
|
void* qGetResultRetrieveMsg(qinfo_t qinfo) {
|
||||||
|
|
|
@ -48,6 +48,13 @@ typedef struct SThreadObj {
|
||||||
void *(*processData)(SRecvInfo *pPacket);
|
void *(*processData)(SRecvInfo *pPacket);
|
||||||
} SThreadObj;
|
} SThreadObj;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
char label[TSDB_LABEL_LEN];
|
||||||
|
int32_t index;
|
||||||
|
int numOfThreads;
|
||||||
|
SThreadObj **pThreadObj;
|
||||||
|
} SClientObj;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
SOCKET fd;
|
SOCKET fd;
|
||||||
uint32_t ip;
|
uint32_t ip;
|
||||||
|
@ -116,6 +123,7 @@ void *taosInitTcpServer(uint32_t ip, uint16_t port, char *label, int numOfThread
|
||||||
pThreadObj->processData = fp;
|
pThreadObj->processData = fp;
|
||||||
tstrncpy(pThreadObj->label, label, sizeof(pThreadObj->label));
|
tstrncpy(pThreadObj->label, label, sizeof(pThreadObj->label));
|
||||||
pThreadObj->shandle = shandle;
|
pThreadObj->shandle = shandle;
|
||||||
|
pThreadObj->stop = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// initialize mutex, thread, fd which may fail
|
// initialize mutex, thread, fd which may fail
|
||||||
|
@ -166,6 +174,7 @@ void *taosInitTcpServer(uint32_t ip, uint16_t port, char *label, int numOfThread
|
||||||
}
|
}
|
||||||
|
|
||||||
static void taosStopTcpThread(SThreadObj* pThreadObj) {
|
static void taosStopTcpThread(SThreadObj* pThreadObj) {
|
||||||
|
if (pThreadObj == NULL) { return;}
|
||||||
// save thread into local variable and signal thread to stop
|
// save thread into local variable and signal thread to stop
|
||||||
pthread_t thread = pThreadObj->thread;
|
pthread_t thread = pThreadObj->thread;
|
||||||
if (!taosCheckPthreadValid(thread)) {
|
if (!taosCheckPthreadValid(thread)) {
|
||||||
|
@ -282,68 +291,104 @@ static void *taosAcceptTcpConnection(void *arg) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void *taosInitTcpClient(uint32_t ip, uint16_t port, char *label, int num, void *fp, void *shandle) {
|
void *taosInitTcpClient(uint32_t ip, uint16_t port, char *label, int numOfThreads, void *fp, void *shandle) {
|
||||||
SThreadObj *pThreadObj;
|
SClientObj *pClientObj = (SClientObj *)calloc(1, sizeof(SClientObj));
|
||||||
|
if (pClientObj == NULL) {
|
||||||
|
tError("TCP:%s no enough memory", label);
|
||||||
|
terrno = TAOS_SYSTEM_ERROR(errno);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
tstrncpy(pClientObj->label, label, sizeof(pClientObj->label));
|
||||||
|
pClientObj->numOfThreads = numOfThreads;
|
||||||
|
pClientObj->pThreadObj = (SThreadObj **)calloc(numOfThreads, sizeof(SThreadObj*));
|
||||||
|
if (pClientObj->pThreadObj == NULL) {
|
||||||
|
tError("TCP:%s no enough memory", label);
|
||||||
|
tfree(pClientObj);
|
||||||
|
terrno = TAOS_SYSTEM_ERROR(errno);
|
||||||
|
}
|
||||||
|
|
||||||
|
int code = 0;
|
||||||
pthread_attr_t thattr;
|
pthread_attr_t thattr;
|
||||||
|
|
||||||
pThreadObj = (SThreadObj *)malloc(sizeof(SThreadObj));
|
|
||||||
memset(pThreadObj, 0, sizeof(SThreadObj));
|
|
||||||
tstrncpy(pThreadObj->label, label, sizeof(pThreadObj->label));
|
|
||||||
pThreadObj->ip = ip;
|
|
||||||
pThreadObj->shandle = shandle;
|
|
||||||
|
|
||||||
if (pthread_mutex_init(&(pThreadObj->mutex), NULL) < 0) {
|
|
||||||
tError("%s failed to init TCP client mutex(%s)", label, strerror(errno));
|
|
||||||
free(pThreadObj);
|
|
||||||
terrno = TAOS_SYSTEM_ERROR(errno);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
pThreadObj->pollFd = (EpollFd)epoll_create(10); // size does not matter
|
|
||||||
if (pThreadObj->pollFd < 0) {
|
|
||||||
tError("%s failed to create TCP client epoll", label);
|
|
||||||
free(pThreadObj);
|
|
||||||
terrno = TAOS_SYSTEM_ERROR(errno);
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
pThreadObj->processData = fp;
|
|
||||||
|
|
||||||
pthread_attr_init(&thattr);
|
pthread_attr_init(&thattr);
|
||||||
pthread_attr_setdetachstate(&thattr, PTHREAD_CREATE_JOINABLE);
|
pthread_attr_setdetachstate(&thattr, PTHREAD_CREATE_JOINABLE);
|
||||||
int code = pthread_create(&(pThreadObj->thread), &thattr, taosProcessTcpData, (void *)(pThreadObj));
|
|
||||||
pthread_attr_destroy(&thattr);
|
for (int i = 0; i < numOfThreads; ++i) {
|
||||||
if (code != 0) {
|
SThreadObj *pThreadObj = (SThreadObj *)calloc(1, sizeof(SThreadObj));
|
||||||
EpollClose(pThreadObj->pollFd);
|
if (pThreadObj == NULL) {
|
||||||
pThreadObj->pollFd = -1;
|
tError("TCP:%s no enough memory", label);
|
||||||
free(pThreadObj);
|
terrno = TAOS_SYSTEM_ERROR(errno);
|
||||||
terrno = TAOS_SYSTEM_ERROR(errno);
|
for (int j=0; j<i; ++j) free(pClientObj->pThreadObj[j]);
|
||||||
tError("%s failed to create TCP read data thread(%s)", label, strerror(errno));
|
free(pClientObj);
|
||||||
return NULL;
|
pthread_attr_destroy(&thattr);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
pClientObj->pThreadObj[i] = pThreadObj;
|
||||||
|
taosResetPthread(&pThreadObj->thread);
|
||||||
|
pThreadObj->ip = ip;
|
||||||
|
pThreadObj->stop = false;
|
||||||
|
tstrncpy(pThreadObj->label, label, sizeof(pThreadObj->label));
|
||||||
|
pThreadObj->shandle = shandle;
|
||||||
|
pThreadObj->processData = fp;
|
||||||
}
|
}
|
||||||
|
|
||||||
tDebug("%s TCP client is initialized, ip:%u:%hu", label, ip, port);
|
// initialize mutex, thread, fd which may fail
|
||||||
|
for (int i = 0; i < numOfThreads; ++i) {
|
||||||
|
SThreadObj *pThreadObj = pClientObj->pThreadObj[i];
|
||||||
|
code = pthread_mutex_init(&(pThreadObj->mutex), NULL);
|
||||||
|
if (code < 0) {
|
||||||
|
tError("%s failed to init TCP process data mutex(%s)", label, strerror(errno));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
return pThreadObj;
|
pThreadObj->pollFd = (int64_t)epoll_create(10); // size does not matter
|
||||||
|
if (pThreadObj->pollFd < 0) {
|
||||||
|
tError("%s failed to create TCP epoll", label);
|
||||||
|
code = -1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
code = pthread_create(&(pThreadObj->thread), &thattr, taosProcessTcpData, (void *)(pThreadObj));
|
||||||
|
if (code != 0) {
|
||||||
|
tError("%s failed to create TCP process data thread(%s)", label, strerror(errno));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
pThreadObj->threadId = i;
|
||||||
|
}
|
||||||
|
if (code != 0) {
|
||||||
|
terrno = TAOS_SYSTEM_ERROR(errno);
|
||||||
|
taosCleanUpTcpClient(pClientObj);
|
||||||
|
pClientObj = NULL;
|
||||||
|
}
|
||||||
|
return pClientObj;
|
||||||
}
|
}
|
||||||
|
|
||||||
void taosStopTcpClient(void *chandle) {
|
void taosStopTcpClient(void *chandle) {
|
||||||
SThreadObj *pThreadObj = chandle;
|
SClientObj *pClientObj = chandle;
|
||||||
if (pThreadObj == NULL) return;
|
|
||||||
|
|
||||||
tDebug ("%s TCP client is stopped", pThreadObj->label);
|
if (pClientObj == NULL) return;
|
||||||
|
|
||||||
|
tDebug ("%s TCP client is stopped", pClientObj->label);
|
||||||
}
|
}
|
||||||
|
|
||||||
void taosCleanUpTcpClient(void *chandle) {
|
void taosCleanUpTcpClient(void *chandle) {
|
||||||
SThreadObj *pThreadObj = chandle;
|
SClientObj *pClientObj = chandle;
|
||||||
if (pThreadObj == NULL) return;
|
if (pClientObj == NULL) return;
|
||||||
|
for (int i = 0; i < pClientObj->numOfThreads; ++i) {
|
||||||
tDebug ("%s TCP client will be cleaned up", pThreadObj->label);
|
SThreadObj *pThreadObj= pClientObj->pThreadObj[i];
|
||||||
taosStopTcpThread(pThreadObj);
|
taosStopTcpThread(pThreadObj);
|
||||||
|
}
|
||||||
|
|
||||||
|
tDebug("%s TCP client is cleaned up", pClientObj->label);
|
||||||
|
tfree(pClientObj->pThreadObj);
|
||||||
|
tfree(pClientObj);
|
||||||
}
|
}
|
||||||
|
|
||||||
void *taosOpenTcpClientConnection(void *shandle, void *thandle, uint32_t ip, uint16_t port) {
|
void *taosOpenTcpClientConnection(void *shandle, void *thandle, uint32_t ip, uint16_t port) {
|
||||||
SThreadObj * pThreadObj = shandle;
|
SClientObj * pClientObj = shandle;
|
||||||
|
int32_t index = atomic_load_32(&pClientObj->index) % pClientObj->numOfThreads;
|
||||||
|
atomic_store_32(&pClientObj->index, index + 1);
|
||||||
|
SThreadObj *pThreadObj = pClientObj->pThreadObj[index];
|
||||||
|
|
||||||
SOCKET fd = taosOpenTcpClientSocket(ip, port, pThreadObj->ip);
|
SOCKET fd = taosOpenTcpClientSocket(ip, port, pThreadObj->ip);
|
||||||
if (fd <= 0) return NULL;
|
if (fd <= 0) return NULL;
|
||||||
|
|
|
@ -3,9 +3,10 @@ PROJECT(TDengine)
|
||||||
|
|
||||||
INCLUDE_DIRECTORIES(${TD_COMMUNITY_DIR}/src/rpc/inc)
|
INCLUDE_DIRECTORIES(${TD_COMMUNITY_DIR}/src/rpc/inc)
|
||||||
INCLUDE_DIRECTORIES(${TD_COMMUNITY_DIR}/src/sync/inc)
|
INCLUDE_DIRECTORIES(${TD_COMMUNITY_DIR}/src/sync/inc)
|
||||||
|
INCLUDE_DIRECTORIES(${TD_COMMUNITY_DIR}/deps/rmonotonic/inc)
|
||||||
AUX_SOURCE_DIRECTORY(src SRC)
|
AUX_SOURCE_DIRECTORY(src SRC)
|
||||||
ADD_LIBRARY(tutil ${SRC})
|
ADD_LIBRARY(tutil ${SRC})
|
||||||
TARGET_LINK_LIBRARIES(tutil pthread osdetail lz4 z)
|
TARGET_LINK_LIBRARIES(tutil pthread osdetail lz4 z rmonotonic)
|
||||||
|
|
||||||
IF (TD_LINUX)
|
IF (TD_LINUX)
|
||||||
TARGET_LINK_LIBRARIES(tutil m rt)
|
TARGET_LINK_LIBRARIES(tutil m rt)
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
#include "tsched.h"
|
#include "tsched.h"
|
||||||
#include "ttimer.h"
|
#include "ttimer.h"
|
||||||
#include "tutil.h"
|
#include "tutil.h"
|
||||||
|
#include "monotonic.h"
|
||||||
|
|
||||||
extern int8_t tscEmbedded;
|
extern int8_t tscEmbedded;
|
||||||
|
|
||||||
|
@ -186,6 +187,10 @@ static void removeTimer(uintptr_t id) {
|
||||||
unlockTimerList(list);
|
unlockTimerList(list);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int64_t getMonotonicMs(void) {
|
||||||
|
return (int64_t) getMonotonicUs() / 1000;
|
||||||
|
}
|
||||||
|
|
||||||
static void addToWheel(tmr_obj_t* timer, uint32_t delay) {
|
static void addToWheel(tmr_obj_t* timer, uint32_t delay) {
|
||||||
timerAddRef(timer);
|
timerAddRef(timer);
|
||||||
// select a wheel for the timer, we are not an accurate timer,
|
// select a wheel for the timer, we are not an accurate timer,
|
||||||
|
@ -201,7 +206,7 @@ static void addToWheel(tmr_obj_t* timer, uint32_t delay) {
|
||||||
|
|
||||||
time_wheel_t* wheel = wheels + timer->wheel;
|
time_wheel_t* wheel = wheels + timer->wheel;
|
||||||
timer->prev = NULL;
|
timer->prev = NULL;
|
||||||
timer->expireAt = taosGetTimestampMs() + delay;
|
timer->expireAt = getMonotonicMs() + delay;
|
||||||
|
|
||||||
pthread_mutex_lock(&wheel->mutex);
|
pthread_mutex_lock(&wheel->mutex);
|
||||||
|
|
||||||
|
@ -334,7 +339,7 @@ tmr_h taosTmrStart(TAOS_TMR_CALLBACK fp, int mseconds, void* param, void* handle
|
||||||
}
|
}
|
||||||
|
|
||||||
static void taosTimerLoopFunc(int signo) {
|
static void taosTimerLoopFunc(int signo) {
|
||||||
int64_t now = taosGetTimestampMs();
|
int64_t now = getMonotonicMs();
|
||||||
|
|
||||||
for (int i = 0; i < tListLen(wheels); i++) {
|
for (int i = 0; i < tListLen(wheels); i++) {
|
||||||
// `expried` is a temporary expire list.
|
// `expried` is a temporary expire list.
|
||||||
|
@ -501,7 +506,7 @@ static void taosTmrModuleInit(void) {
|
||||||
|
|
||||||
pthread_mutex_init(&tmrCtrlMutex, NULL);
|
pthread_mutex_init(&tmrCtrlMutex, NULL);
|
||||||
|
|
||||||
int64_t now = taosGetTimestampMs();
|
int64_t now = getMonotonicMs();
|
||||||
for (int i = 0; i < tListLen(wheels); i++) {
|
for (int i = 0; i < tListLen(wheels); i++) {
|
||||||
time_wheel_t* wheel = wheels + i;
|
time_wheel_t* wheel = wheels + i;
|
||||||
if (pthread_mutex_init(&wheel->mutex, NULL) != 0) {
|
if (pthread_mutex_init(&wheel->mutex, NULL) != 0) {
|
||||||
|
@ -532,6 +537,8 @@ static void taosTmrModuleInit(void) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void* taosTmrInit(int maxNumOfTmrs, int resolution, int longest, const char* label) {
|
void* taosTmrInit(int maxNumOfTmrs, int resolution, int longest, const char* label) {
|
||||||
|
tmrInfo("ttimer monotonic clock source:%s", monotonicInit());
|
||||||
|
|
||||||
pthread_once(&tmrModuleInit, taosTmrModuleInit);
|
pthread_once(&tmrModuleInit, taosTmrModuleInit);
|
||||||
|
|
||||||
pthread_mutex_lock(&tmrCtrlMutex);
|
pthread_mutex_lock(&tmrCtrlMutex);
|
||||||
|
|
|
@ -341,7 +341,7 @@ int32_t vnodeWriteCfg(SCreateVnodeMsg *pMsg) {
|
||||||
len += snprintf(content + len, maxLen - len, "}\n");
|
len += snprintf(content + len, maxLen - len, "}\n");
|
||||||
|
|
||||||
fwrite(content, 1, len, fp);
|
fwrite(content, 1, len, fp);
|
||||||
fflush(fp);
|
fsync(fileno(fp));
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
free(content);
|
free(content);
|
||||||
terrno = 0;
|
terrno = 0;
|
||||||
|
|
|
@ -90,7 +90,7 @@ int32_t vnodeSaveVersion(SVnodeObj *pVnode) {
|
||||||
len += snprintf(content + len, maxLen - len, "}\n");
|
len += snprintf(content + len, maxLen - len, "}\n");
|
||||||
|
|
||||||
fwrite(content, 1, len, fp);
|
fwrite(content, 1, len, fp);
|
||||||
fflush(fp);
|
fsync(fileno(fp));
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
free(content);
|
free(content);
|
||||||
terrno = 0;
|
terrno = 0;
|
||||||
|
|
|
@ -47,7 +47,7 @@
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.taosdata.jdbc</groupId>
|
<groupId>com.taosdata.jdbc</groupId>
|
||||||
<artifactId>taos-jdbcdriver</artifactId>
|
<artifactId>taos-jdbcdriver</artifactId>
|
||||||
<version>2.0.4</version>
|
<version>2.0.18</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
|
@ -69,7 +69,7 @@
|
||||||
<configuration>
|
<configuration>
|
||||||
<archive>
|
<archive>
|
||||||
<manifest>
|
<manifest>
|
||||||
<mainClass>com.taosdata.jdbc.example.jdbcTemplate.App</mainClass>
|
<mainClass>com.taosdata.example.jdbcTemplate.App</mainClass>
|
||||||
</manifest>
|
</manifest>
|
||||||
</archive>
|
</archive>
|
||||||
<descriptorRefs>
|
<descriptorRefs>
|
||||||
|
|
|
@ -8,18 +8,16 @@
|
||||||
修改 `src/main/resources/applicationContext.xml` 文件中 TDengine 的配置信息:
|
修改 `src/main/resources/applicationContext.xml` 文件中 TDengine 的配置信息:
|
||||||
|
|
||||||
```xml
|
```xml
|
||||||
|
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
|
||||||
|
<property name="driverClassName" value="com.taosdata.jdbc.TSDBDriver"></property>
|
||||||
|
<property name="url" value="jdbc:TAOS://127.0.0.1:6030/log"></property>
|
||||||
|
<property name="username" value="root"></property>
|
||||||
|
<property name="password" value="taosdata"></property>
|
||||||
|
</bean>
|
||||||
|
|
||||||
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
|
<bean id = "jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate" >
|
||||||
<property name="driverClassName" value="com.taosdata.jdbc.TSDBDriver"></property>
|
<property name="dataSource" ref = "dataSource" ></property>
|
||||||
<property name="url" value="jdbc:TAOS://127.0.0.1:6030/log"></property>
|
</bean>
|
||||||
<property name="username" value="root"></property>
|
|
||||||
<property name="password" value="taosdata"></property>
|
|
||||||
</bean>
|
|
||||||
|
|
||||||
|
|
||||||
<bean id = "jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate" >
|
|
||||||
<property name="dataSource" ref = "dataSource" ></property>
|
|
||||||
</bean>
|
|
||||||
```
|
```
|
||||||
|
|
||||||
### 打包运行
|
### 打包运行
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
package com.taosdata.jdbc.example.jdbcTemplate;
|
package com.taosdata.example.jdbcTemplate;
|
||||||
|
|
||||||
|
|
||||||
import com.taosdata.jdbc.example.jdbcTemplate.dao.ExecuteAsStatement;
|
import com.taosdata.example.jdbcTemplate.dao.ExecuteAsStatement;
|
||||||
import com.taosdata.jdbc.example.jdbcTemplate.dao.WeatherDao;
|
import com.taosdata.example.jdbcTemplate.dao.WeatherDao;
|
||||||
import com.taosdata.jdbc.example.jdbcTemplate.domain.Weather;
|
import com.taosdata.example.jdbcTemplate.domain.Weather;
|
||||||
import org.springframework.context.ApplicationContext;
|
import org.springframework.context.ApplicationContext;
|
||||||
import org.springframework.context.support.ClassPathXmlApplicationContext;
|
import org.springframework.context.support.ClassPathXmlApplicationContext;
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
package com.taosdata.jdbc.example.jdbcTemplate.dao;
|
package com.taosdata.example.jdbcTemplate.dao;
|
||||||
|
|
||||||
public interface ExecuteAsStatement{
|
public interface ExecuteAsStatement{
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
package com.taosdata.jdbc.example.jdbcTemplate.dao.impl;
|
package com.taosdata.example.jdbcTemplate.dao;
|
||||||
|
|
||||||
import com.taosdata.jdbc.example.jdbcTemplate.dao.ExecuteAsStatement;
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.jdbc.core.JdbcTemplate;
|
import org.springframework.jdbc.core.JdbcTemplate;
|
||||||
import org.springframework.stereotype.Repository;
|
import org.springframework.stereotype.Repository;
|
|
@ -1,6 +1,6 @@
|
||||||
package com.taosdata.jdbc.example.jdbcTemplate.dao;
|
package com.taosdata.example.jdbcTemplate.dao;
|
||||||
|
|
||||||
import com.taosdata.jdbc.example.jdbcTemplate.domain.Weather;
|
import com.taosdata.example.jdbcTemplate.domain.Weather;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
|
@ -1,20 +1,16 @@
|
||||||
package com.taosdata.jdbc.example.jdbcTemplate.dao.impl;
|
package com.taosdata.example.jdbcTemplate.dao;
|
||||||
|
|
||||||
import com.taosdata.jdbc.example.jdbcTemplate.dao.WeatherDao;
|
import com.taosdata.example.jdbcTemplate.domain.Weather;
|
||||||
import com.taosdata.jdbc.example.jdbcTemplate.domain.Weather;
|
import com.taosdata.example.jdbcTemplate.dao.WeatherDao;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.jdbc.core.BatchPreparedStatementSetter;
|
import org.springframework.jdbc.core.BatchPreparedStatementSetter;
|
||||||
import org.springframework.jdbc.core.JdbcTemplate;
|
import org.springframework.jdbc.core.JdbcTemplate;
|
||||||
import org.springframework.jdbc.core.namedparam.SqlParameterSourceUtils;
|
|
||||||
import org.springframework.jdbc.core.simple.SimpleJdbcInsert;
|
|
||||||
import org.springframework.stereotype.Repository;
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
||||||
import java.sql.PreparedStatement;
|
import java.sql.PreparedStatement;
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
import java.sql.Timestamp;
|
import java.sql.Timestamp;
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
@Repository
|
@Repository
|
||||||
public class WeatherDaoImpl implements WeatherDao {
|
public class WeatherDaoImpl implements WeatherDao {
|
|
@ -1,4 +1,4 @@
|
||||||
package com.taosdata.jdbc.example.jdbcTemplate.domain;
|
package com.taosdata.example.jdbcTemplate.domain;
|
||||||
|
|
||||||
import java.sql.Timestamp;
|
import java.sql.Timestamp;
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
|
|
||||||
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
|
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
|
||||||
<property name="driverClassName" value="com.taosdata.jdbc.TSDBDriver"></property>
|
<property name="driverClassName" value="com.taosdata.jdbc.TSDBDriver"></property>
|
||||||
<property name="url" value="jdbc:TAOS://192.168.236.137:6030/"></property>
|
<property name="url" value="jdbc:TAOS://127.0.0.1:6030/"></property>
|
||||||
<property name="username" value="root"></property>
|
<property name="username" value="root"></property>
|
||||||
<property name="password" value="taosdata"></property>
|
<property name="password" value="taosdata"></property>
|
||||||
</bean>
|
</bean>
|
||||||
|
@ -20,6 +20,6 @@
|
||||||
<property name="dataSource" ref="dataSource"></property>
|
<property name="dataSource" ref="dataSource"></property>
|
||||||
</bean>
|
</bean>
|
||||||
|
|
||||||
<context:component-scan base-package="com.taosdata.jdbc.example.jdbcTemplate"/>
|
<context:component-scan base-package="com.taosdata.example.jdbcTemplate"/>
|
||||||
|
|
||||||
</beans>
|
</beans>
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
package com.taosdata.jdbc.example.jdbcTemplate;
|
package com.taosdata.example.jdbcTemplate;
|
||||||
|
|
||||||
|
|
||||||
import com.taosdata.jdbc.example.jdbcTemplate.dao.ExecuteAsStatement;
|
import com.taosdata.example.jdbcTemplate.dao.ExecuteAsStatement;
|
||||||
import com.taosdata.jdbc.example.jdbcTemplate.dao.WeatherDao;
|
import com.taosdata.example.jdbcTemplate.dao.WeatherDao;
|
||||||
import com.taosdata.jdbc.example.jdbcTemplate.domain.Weather;
|
import com.taosdata.example.jdbcTemplate.domain.Weather;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
|
@ -1,18 +0,0 @@
|
||||||
package com.taosdata.jdbc;
|
|
||||||
|
|
||||||
import static org.junit.Assert.assertTrue;
|
|
||||||
|
|
||||||
import org.junit.Test;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Unit test for simple App.
|
|
||||||
*/
|
|
||||||
public class AppTest {
|
|
||||||
/**
|
|
||||||
* Rigorous Test :-)
|
|
||||||
*/
|
|
||||||
@Test
|
|
||||||
public void shouldAnswerWithTrue() {
|
|
||||||
assertTrue(true);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -0,0 +1,13 @@
|
||||||
|
# TDengine examples
|
||||||
|
|
||||||
|
| No. | Name | Describe |
|
||||||
|
| :--: | :----------------: | ------------------------------------------------------------ |
|
||||||
|
| 1 | JDBCDemo | Example codes for JDBC-JNI, JDBC-RESTful, Subscribe |
|
||||||
|
| 2 | connectionPools | Example codes for HikariCP, Druid, dbcp, c3p0 connection pools |
|
||||||
|
| 3 | SpringJdbcTemplate | Example codes for spring jdbcTemplate |
|
||||||
|
| 4 | mybatisplus-demo | Example codes for mybatis |
|
||||||
|
| 5 | springbootdemo | Example codes for springboot |
|
||||||
|
| 6 | taosdemo | This is an internal tool for testing Our JDBC-JNI, JDBC-RESTful, RESTful interfaces |
|
||||||
|
|
||||||
|
|
||||||
|
more detail: https://www.taosdata.com/cn//documentation20/connector-java/
|
|
@ -20,6 +20,7 @@ python3 insert/retentionpolicy.py
|
||||||
python3 ./test.py -f insert/alterTableAndInsert.py
|
python3 ./test.py -f insert/alterTableAndInsert.py
|
||||||
python3 ./test.py -f insert/insertIntoTwoTables.py
|
python3 ./test.py -f insert/insertIntoTwoTables.py
|
||||||
#python3 ./test.py -f insert/before_1970.py
|
#python3 ./test.py -f insert/before_1970.py
|
||||||
|
python3 ./test.py -f insert/metadataUpdate.py
|
||||||
python3 bug2265.py
|
python3 bug2265.py
|
||||||
|
|
||||||
#table
|
#table
|
||||||
|
|
|
@ -0,0 +1,67 @@
|
||||||
|
###################################################################
|
||||||
|
# Copyright (c) 2016 by TAOS Technologies, Inc.
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# This file is proprietary and confidential to TAOS Technologies.
|
||||||
|
# No part of this file may be reproduced, stored, transmitted,
|
||||||
|
# disclosed or used in any form or by any means other than as
|
||||||
|
# expressly provided by the written permission from Jianhui Tao
|
||||||
|
#
|
||||||
|
###################################################################
|
||||||
|
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
import sys
|
||||||
|
import taos
|
||||||
|
from util.log import tdLog
|
||||||
|
from util.cases import tdCases
|
||||||
|
from util.sql import tdSql
|
||||||
|
from util.dnodes import tdDnodes
|
||||||
|
from multiprocessing import Process
|
||||||
|
|
||||||
|
class TDTestCase:
|
||||||
|
def init(self, conn, logSql):
|
||||||
|
tdLog.debug("start to execute %s" % __file__)
|
||||||
|
tdSql.init(conn.cursor(), logSql)
|
||||||
|
|
||||||
|
self.ts = 1538548685000
|
||||||
|
|
||||||
|
def updateMetadata(self):
|
||||||
|
self.host = "127.0.0.1"
|
||||||
|
self.user = "root"
|
||||||
|
self.password = "taosdata"
|
||||||
|
self.config = tdDnodes.getSimCfgPath()
|
||||||
|
|
||||||
|
self.conn = taos.connect(host = self.host, user = self.user, password = self.password, config = self.config)
|
||||||
|
self.cursor = self.conn.cursor()
|
||||||
|
self.cursor.execute("alter table db.tb add column col2 int")
|
||||||
|
print("alter table done")
|
||||||
|
|
||||||
|
def run(self):
|
||||||
|
tdSql.prepare()
|
||||||
|
|
||||||
|
print("==============step1")
|
||||||
|
tdSql.execute("create table if not exists tb (ts timestamp, col1 int)")
|
||||||
|
tdSql.execute("insert into tb values(%d, 1)" % self.ts)
|
||||||
|
|
||||||
|
print("==============step2")
|
||||||
|
tdSql.query("select * from tb")
|
||||||
|
tdSql.checkRows(1)
|
||||||
|
|
||||||
|
p = Process(target=self.updateMetadata, args=())
|
||||||
|
p.start()
|
||||||
|
p.join()
|
||||||
|
p.terminate()
|
||||||
|
|
||||||
|
tdSql.execute("insert into tb values(%d, 1, 2)" % (self.ts + 1))
|
||||||
|
|
||||||
|
print("==============step2")
|
||||||
|
tdSql.query("select * from tb")
|
||||||
|
tdSql.checkRows(2)
|
||||||
|
|
||||||
|
def stop(self):
|
||||||
|
tdSql.close()
|
||||||
|
tdLog.success("%s successfully executed" % __file__)
|
||||||
|
|
||||||
|
tdCases.addWindows(__file__, TDTestCase())
|
||||||
|
tdCases.addLinux(__file__, TDTestCase())
|
|
@ -26,11 +26,11 @@ sql use ' XYZ '
|
||||||
|
|
||||||
sql drop database 'abc123'
|
sql drop database 'abc123'
|
||||||
sql drop database '_ab1234'
|
sql drop database '_ab1234'
|
||||||
sql drop database 'ABC123'
|
sql_error drop database 'ABC123'
|
||||||
sql drop database '_ABC123'
|
sql drop database '_ABC123'
|
||||||
sql drop database 'aABb123'
|
sql drop database 'aABb123'
|
||||||
sql drop database ' xyz '
|
sql drop database ' xyz '
|
||||||
sql drop database ' XYZ '
|
sql_error drop database ' XYZ '
|
||||||
|
|
||||||
|
|
||||||
sql use abc
|
sql use abc
|
||||||
|
@ -67,9 +67,9 @@ sql describe mt
|
||||||
sql describe sub_001
|
sql describe sub_001
|
||||||
sql describe sub_dy_tbl
|
sql describe sub_dy_tbl
|
||||||
|
|
||||||
sql_error describe Dd
|
sql describe Dd
|
||||||
sql_error describe FF
|
sql describe FF
|
||||||
sql_error describe gG
|
sql describe gG
|
||||||
|
|
||||||
sql drop table abc.cc
|
sql drop table abc.cc
|
||||||
sql drop table 'abc.Dd'
|
sql drop table 'abc.Dd'
|
||||||
|
@ -119,4 +119,4 @@ if $rows != 4 then
|
||||||
return -1
|
return -1
|
||||||
endi
|
endi
|
||||||
|
|
||||||
system sh/exec.sh -n dnode1 -s stop -x SIGINT
|
system sh/exec.sh -n dnode1 -s stop -x SIGINT
|
||||||
|
|
Loading…
Reference in New Issue