mirror of
https://github.com/zerotier/ZeroTierOne.git
synced 2025-01-18 10:46:33 +00:00
Updated compatibility section
This commit is contained in:
parent
48d9708abe
commit
284b37ccc0
@ -303,7 +303,7 @@ int init_service_connection()
|
|||||||
void my_dest(void) __attribute__ ((destructor));
|
void my_dest(void) __attribute__ ((destructor));
|
||||||
void my_dest(void) {
|
void my_dest(void) {
|
||||||
dwr(MSG_DEBUG,"closing connections to service...\n");
|
dwr(MSG_DEBUG,"closing connections to service...\n");
|
||||||
close(fdret_sock);
|
//close(fdret_sock);
|
||||||
pthread_mutex_destroy(&lock);
|
pthread_mutex_destroy(&lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1010,8 +1010,8 @@ int dup2(DUP2_SIG)
|
|||||||
errno = EBADF;
|
errno = EBADF;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if(oldfd != STDIN_FILENO && oldfd != STDOUT_FILENO && oldfd != STDERR_FILENO)
|
//if(oldfd != STDIN_FILENO && oldfd != STDOUT_FILENO && oldfd != STDERR_FILENO)
|
||||||
if(newfd != STDIN_FILENO && newfd != STDOUT_FILENO && newfd != STDERR_FILENO)
|
// if(newfd != STDIN_FILENO && newfd != STDOUT_FILENO && newfd != STDERR_FILENO)
|
||||||
return realdup2(oldfd, newfd);
|
return realdup2(oldfd, newfd);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -23,17 +23,17 @@ The virtual TCP/IP stack will respond to *incoming* ICMP ECHO requests, which me
|
|||||||
|
|
||||||
#### Compatibility Test Results
|
#### Compatibility Test Results
|
||||||
|
|
||||||
sshd [ WORKS as of 20151112 ]
|
sshd [ WORKS as of 20151207 ] Should be run with in debug mode with -d
|
||||||
ssh [ WORKS as of 20151112 ]
|
ssh [ WORKS as of 20151112 ]
|
||||||
sftp [ WORKS as of 20151022 ]
|
sftp [ WORKS as of 20151022 ]
|
||||||
curl [ WORKS as of 20151021 ]
|
curl [ WORKS as of 20151021 ]
|
||||||
apache (debug mode) [ WORKS as of 20150810 ]
|
apache (debug mode -X) [ WORKS as of 20151207 ] (2.4.6-31.x86_64 on Centos 7), (2.4.16-1.x84_64 on F22/F23), (2.4.17-3.x86_64 on F22/F23)
|
||||||
apache (prefork MPM) [ WORKS as of 20151123 ] (2.4.6-31.x86-64 on Centos 7), (2.4.16-1.x84-64 on F22), (2.4.17-3.x86-64 on F22)
|
apache (prefork MPM) [ WORKS as of 20151123 ]
|
||||||
nginx [ MARGINAL as of 20151123 ] Broken on Centos 7, unreliable on Fedora 23
|
nginx [ BROKEN as of 20151207 ]
|
||||||
nodejs [ WORKS as of 20151123 ]
|
nodejs [ WORKS as of 20151207 ] (0.10.36-4.fc23)
|
||||||
java [ WORKS as of 20151010 ]
|
java [ WORKS as of 20151010 ]
|
||||||
MongoDB [ WORKS as of 20151028 ]
|
MongoDB [ WORKS as of 20151028 ]
|
||||||
Redis-server [ WORKS as of 20151123 ]
|
Redis-server [ WORKS as of 20151207 ] (3.0.4-1.fc23.x86_64)
|
||||||
|
|
||||||
It is *likely* to work with other things but there are no guarantees. UDP, ICMP/RAW, and IPv6 support are planned for the near future.
|
It is *likely* to work with other things but there are no guarantees. UDP, ICMP/RAW, and IPv6 support are planned for the near future.
|
||||||
|
|
||||||
|
@ -0,0 +1,24 @@
|
|||||||
|
# ZT Network Containers Test Monitor
|
||||||
|
FROM fedora:23
|
||||||
|
MAINTAINER https://www.zerotier.com/
|
||||||
|
|
||||||
|
EXPOSE 9993/udp
|
||||||
|
|
||||||
|
# Add ZT files
|
||||||
|
RUN mkdir -p /var/lib/zerotier-one/networks.d
|
||||||
|
ADD monitor_identity.public /var/lib/zerotier-one/identity.public
|
||||||
|
ADD monitor_identity.secret /var/lib/zerotier-one/identity.secret
|
||||||
|
ADD *.conf /var/lib/zerotier-one/networks.d/
|
||||||
|
ADD *.conf /
|
||||||
|
ADD *.name /
|
||||||
|
|
||||||
|
# Install LWIP library used by service
|
||||||
|
ADD liblwip.so /var/lib/zerotier-one/liblwip.so
|
||||||
|
|
||||||
|
ADD zerotier-one /
|
||||||
|
ADD zerotier-cli /
|
||||||
|
|
||||||
|
# Start ZeroTier-One
|
||||||
|
ADD monitor_entrypoint.sh /monitor_entrypoint.sh
|
||||||
|
RUN chmod -v +x /monitor_entrypoint.sh
|
||||||
|
CMD ["./monitor_entrypoint.sh"]
|
@ -0,0 +1,80 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
export PATH=/bin:/usr/bin:/usr/local/bin:/sbin:/usr/sbin:/
|
||||||
|
|
||||||
|
|
||||||
|
# --- Test Parameters ---
|
||||||
|
test_namefile=$(ls *.name)
|
||||||
|
test_name="${test_namefile%.*}" # test network id
|
||||||
|
nwconf=$(ls *.conf) # blank test network config file
|
||||||
|
nwid="${nwconf%.*}" # test network id
|
||||||
|
netcon_wait_time=35 # wait for test container to come online
|
||||||
|
app_timeout_time=25 # app-specific timeout
|
||||||
|
file_path=/opt/results/ # test result output file path (fs shared between host and containers)
|
||||||
|
file_base="$test_name".txt # test result output file
|
||||||
|
fail=FAIL. # appended to result file in event of failure
|
||||||
|
ok=OK. # appended to result file in event of success
|
||||||
|
tmp_ext=.tmp # temporary filetype used for sharing test data between containers
|
||||||
|
address_file="$file_path$test_name"_addr"$tmp_ext" # file shared between host and containers for sharing address (optional)
|
||||||
|
bigfile_name=bigfile # large, random test transfer file
|
||||||
|
rx_md5sumfile="$file_path"rx_"$bigfile_name"_md5sum"$tmp_ext"
|
||||||
|
tx_md5sumfile="$file_path"tx_"$bigfile_name"_md5sum"$tmp_ext"
|
||||||
|
|
||||||
|
|
||||||
|
# --- Network Config ---
|
||||||
|
echo '*** ZeroTier Network Containers Test Monitor'
|
||||||
|
chown -R daemon /var/lib/zerotier-one
|
||||||
|
chgrp -R daemon /var/lib/zerotier-one
|
||||||
|
su daemon -s /bin/bash -c '/zerotier-one -d -U -p9993 >>/tmp/zerotier-one.out 2>&1'
|
||||||
|
virtip4=""
|
||||||
|
while [ -z "$virtip4" ]; do
|
||||||
|
sleep 0.2
|
||||||
|
virtip4=`/zerotier-cli listnetworks | grep -F $nwid | cut -d ' ' -f 9 | sed 's/,/\n/g' | grep -F '.' | cut -d / -f 1`
|
||||||
|
done
|
||||||
|
echo '*** Starting Test...'
|
||||||
|
echo '*** Up and running at' $virtip4 ' on network: ' $nwid
|
||||||
|
echo '*** Sleeping for (' "$netcon_wait_time" 's ) while we wait for the Network Container to come online...'
|
||||||
|
sleep "$netcon_wait_time"s
|
||||||
|
ncvirtip=$(<$address_file)
|
||||||
|
|
||||||
|
|
||||||
|
# --- Test section ---
|
||||||
|
echo '*** Curling from intercepted server at' $ncvirtip
|
||||||
|
rm -rf "$file_path"*."$file_base"
|
||||||
|
touch "$bigfile_name"
|
||||||
|
|
||||||
|
# Perform test
|
||||||
|
# curl --connect-timeout "$app_timeout_time" -v -o "$file_path$file_base" http://"$ncvirtip"/index.html
|
||||||
|
# Large transfer test
|
||||||
|
curl --connect-timeout "$app_timeout_time" -v -o "$bigfile_name" http://"$ncvirtip"/"$bigfile_name"
|
||||||
|
|
||||||
|
# Check md5
|
||||||
|
md5sum < "$bigfile_name" > "$rx_md5sumfile"
|
||||||
|
rx_md5sum=$(<$rx_md5sumfile)
|
||||||
|
tx_md5sum=$(<$tx_md5sumfile)
|
||||||
|
|
||||||
|
echo '*** Comparing md5: ' "$rx_md5sum" ' and ' "$tx_md5sum"
|
||||||
|
|
||||||
|
if [ "$rx_md5sum" != "$tx_md5sum" ];
|
||||||
|
then
|
||||||
|
echo 'MD5 FAIL'
|
||||||
|
touch "$file_path$fail$test_name.txt"
|
||||||
|
printf 'Test: md5 sum did not match!\n' >> "$file_path$fail$test_name.txt"
|
||||||
|
else
|
||||||
|
echo 'MD5 OK'
|
||||||
|
touch "$file_path$ok$test_name.txt"
|
||||||
|
printf 'Test: md5 sum ok!\n' >> "$file_path$ok$test_name.txt"
|
||||||
|
cat "$rx_md5sumfile" >> "$file_path$ok$test_name.txt"
|
||||||
|
cat "$tx_md5sumfile" >> "$file_path$ok$test_name.txt"
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -0,0 +1,40 @@
|
|||||||
|
# ZT Network Containers Test
|
||||||
|
FROM ubuntu:14.04
|
||||||
|
MAINTAINER https://www.zerotier.com/
|
||||||
|
|
||||||
|
RUN \
|
||||||
|
sed -i 's/# \(.*multiverse$\)/\1/g' /etc/apt/sources.list && \
|
||||||
|
apt-get update && \
|
||||||
|
apt-get -y upgrade && \
|
||||||
|
apt-get -y install apache2
|
||||||
|
|
||||||
|
EXPOSE 9993/udp 80/udp
|
||||||
|
|
||||||
|
# Add ZT files
|
||||||
|
RUN mkdir -p /var/lib/zerotier-one/networks.d
|
||||||
|
ADD netcon_identity.public /var/lib/zerotier-one/identity.public
|
||||||
|
ADD netcon_identity.secret /var/lib/zerotier-one/identity.secret
|
||||||
|
ADD *.conf /var/lib/zerotier-one/networks.d/
|
||||||
|
ADD *.conf /
|
||||||
|
ADD *.name /
|
||||||
|
|
||||||
|
# Install LWIP library used by service
|
||||||
|
ADD liblwip.so /var/lib/zerotier-one/liblwip.so
|
||||||
|
|
||||||
|
# Install syscall intercept library
|
||||||
|
ADD zerotier-intercept /
|
||||||
|
ADD libzerotierintercept.so /
|
||||||
|
RUN cp libzerotierintercept.so lib/libzerotierintercept.so
|
||||||
|
RUN ln -sf /lib/libzerotierintercept.so /lib/libzerotierintercept
|
||||||
|
RUN /usr/bin/install -c zerotier-intercept /usr/bin
|
||||||
|
|
||||||
|
ADD zerotier-one /
|
||||||
|
ADD zerotier-cli /
|
||||||
|
ADD zerotier-netcon-service /
|
||||||
|
|
||||||
|
# Install test scripts
|
||||||
|
ADD netcon_entrypoint.sh /netcon_entrypoint.sh
|
||||||
|
RUN chmod -v +x /netcon_entrypoint.sh
|
||||||
|
|
||||||
|
# Start ZeroTier-One
|
||||||
|
CMD ["./netcon_entrypoint.sh"]
|
@ -0,0 +1,46 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
export PATH=/bin:/usr/bin:/usr/local/bin:/sbin:/usr/sbin:/
|
||||||
|
|
||||||
|
|
||||||
|
# --- Test Parameters ---
|
||||||
|
test_namefile=$(ls *.name)
|
||||||
|
test_name="${test_namefile%.*}" # test network id
|
||||||
|
nwconf=$(ls *.conf) # blank test network config file
|
||||||
|
nwid="${nwconf%.*}" # test network id
|
||||||
|
file_path=/opt/results/ # test result output file path (fs shared between host and containers)
|
||||||
|
file_base="$test_name".txt # test result output file
|
||||||
|
tmp_ext=.tmp # temporary filetype used for sharing test data between containers
|
||||||
|
address_file="$file_path$test_name"_addr"$tmp_ext" # file shared between host and containers for sharing address (optional)
|
||||||
|
bigfile_name=bigfile
|
||||||
|
bigfile_size=10M # size of file we want to use for the test
|
||||||
|
tx_md5sumfile="$file_path"tx_"$bigfile_name"_md5sum"$tmp_ext"
|
||||||
|
|
||||||
|
# --- Network Config ---
|
||||||
|
echo '*** ZeroTier Network Containers Test: ' "$test_name"
|
||||||
|
chown -R daemon /var/lib/zerotier-one
|
||||||
|
chgrp -R daemon /var/lib/zerotier-one
|
||||||
|
su daemon -s /bin/bash -c '/zerotier-netcon-service -d -U -p9993 >>/tmp/zerotier-netcon-service.out 2>&1'
|
||||||
|
virtip4=""
|
||||||
|
while [ -z "$virtip4" ]; do
|
||||||
|
sleep 0.2
|
||||||
|
virtip4=`/zerotier-cli listnetworks | grep -F $nwid | cut -d ' ' -f 9 | sed 's/,/\n/g' | grep -F '.' | cut -d / -f 1`
|
||||||
|
dev=`/zerotier-cli listnetworks | grep -F "" | cut -d ' ' -f 8 | cut -d "_" -f 2 | sed "s/^<dev>//" | tr '\n' '\0'`
|
||||||
|
done
|
||||||
|
echo '--- Up and running at' $virtip4 ' on network: ' $nwid
|
||||||
|
echo '*** Writing address to ' "$address_file"
|
||||||
|
echo $virtip4 > "$address_file"
|
||||||
|
|
||||||
|
export ZT_NC_NWID=$dev
|
||||||
|
|
||||||
|
# --- Test section ---
|
||||||
|
# Generate large random file for transfer test, share md5sum for monitor container to check
|
||||||
|
echo '*** Generating ' "$bigfile_size" ' file'
|
||||||
|
dd if=/dev/urandom of=/var/www/html/"$bigfile_name" bs="$bigfile_size" count=1
|
||||||
|
md5sum < /var/www/html/"$bigfile_name" > "$tx_md5sumfile"
|
||||||
|
echo '*** Wrote MD5 sum to ' "$tx_md5sumfile"
|
||||||
|
|
||||||
|
echo '*** Starting application...'
|
||||||
|
sleep 0.5
|
||||||
|
rm -rf /run/httpd/* /tmp/httpd*
|
||||||
|
zerotier-intercept /usr/sbin/httpd -D FOREGROUND >>/tmp/apache.out 2>&1
|
Loading…
Reference in New Issue
Block a user