Browse Source

update: check port status by psutil

master
dnomd343 2 years ago
parent
commit
234ba7f4d5
  1. 69
      Basis/Functions.py
  2. 85
      Dockerfile
  3. 3
      test.py

69
Basis/Functions.py

@ -2,8 +2,8 @@
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
import time import time
import psutil
import random import random
import socket
from Basis.Logger import logging from Basis.Logger import logging
@ -31,38 +31,35 @@ def getAvailablePort(rangeStart: int = 41952, rangeEnd: int = 65535) -> int: #
def checkPortStatus(port: int) -> bool: # check if the port is occupied def checkPortStatus(port: int) -> bool: # check if the port is occupied
ipv4Tcp = None logging.debug('check status of port %i -> available' % port)
ipv4Udp = None for connection in networkStatus(): # scan every connections
ipv6Tcp = None if connection['local']['port'] == port: # port occupied (whatever ipv4-tcp / ipv4-udp / ipv6-tcp / ipv6-udp)
ipv6Udp = None logging.debug('check status of port %i -> occupied' % port)
try: return False
ipv4Tcp = socket.socket(socket.AF_INET, socket.SOCK_STREAM) return True
ipv4Udp = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
ipv4Tcp.bind(('0.0.0.0', port))
ipv4Udp.bind(('0.0.0.0', port)) def networkStatus() -> list: # get all network connections
ipv4Tcp.close() result = []
ipv4Udp.close() for connection in psutil.net_connections():
ipv6Tcp = socket.socket(socket.AF_INET6, socket.SOCK_STREAM) if not connection.family.name.startswith('AF_INET'): # AF_INET / AF_INET6
ipv6Udp = socket.socket(socket.AF_INET6, socket.SOCK_DGRAM) continue
ipv6Tcp.bind(('::', port)) if connection.type.name not in ['SOCK_STREAM', 'SOCK_DGRAM']: # TCP / UDP
ipv6Udp.bind(('::', port)) continue
ipv6Tcp.close() result.append({
ipv6Udp.close() 'fd': connection.fd,
logging.debug('check status of port %i -> available' % port) 'family': 'ipv6' if connection.family.name[-1] == '6' else 'ipv4', # ip version
return True # IPv4 TCP / IPv4 UDP / IPv6 TCP / IPv6 UDP are normal 'type': 'tcp' if connection.type.name == 'SOCK_STREAM' else 'udp', # tcp or udp
except: 'local': { # local bind address
logging.debug('check status of port %i -> occupied' % port) 'addr': connection.laddr.ip,
return False 'port': connection.laddr.port,
finally: # close socket },
try: 'remote': { # remote address
ipv4Tcp.close() 'addr': connection.raddr.ip,
except: pass 'port': connection.raddr.port,
try: } if len(connection.raddr) != 0 else None,
ipv4Udp.close() 'status': connection.status,
except: pass 'pid': connection.pid, # process id
try: })
ipv6Tcp.close() logging.debug('get network status -> found %i connections' % len(result))
except: pass return result
try:
ipv6Udp.close()
except: pass

85
Dockerfile

@ -90,6 +90,20 @@ RUN \
mv ../bin/ss-bootstrap-* /tmp/ mv ../bin/ss-bootstrap-* /tmp/
RUN strip /tmp/ss-bootstrap-* RUN strip /tmp/ss-bootstrap-*
# Combine shadowsocks dependencies
FROM python:3.10-alpine3.16 AS shadowsocks
COPY --from=ss-rust /tmp/ss-rust-* /release/
COPY --from=ss-libev /tmp/ss-libev-* /release/
COPY --from=ss-bootstrap /tmp/ss-bootstrap-* /release/
RUN \
PYTHON_PACKAGE="/usr/local/lib/$(ls /usr/local/lib/ | grep ^python)/site-packages" && \
ln -s ${PYTHON_PACKAGE}/ssr-python/local.py /release/ssr-local && \
ln -s ${PYTHON_PACKAGE}/ssr-python/server.py /release/ssr-server && \
ln -s ${PYTHON_PACKAGE}/ss-python/local.py /release/ss-python-local && \
ln -s ${PYTHON_PACKAGE}/ss-python/server.py /release/ss-python-server && \
ln -s ${PYTHON_PACKAGE}/ss-python-legacy/local.py /release/ss-python-legacy-local && \
ln -s ${PYTHON_PACKAGE}/ss-python-legacy/server.py /release/ss-python-legacy-server
# Compile openssl (old version, for shadowsocks method -> idea-cfb / seed-cfb) # Compile openssl (old version, for shadowsocks method -> idea-cfb / seed-cfb)
FROM alpine:3.16 AS openssl FROM alpine:3.16 AS openssl
ENV OPENSSL_VER="1.0.2" ENV OPENSSL_VER="1.0.2"
@ -103,32 +117,16 @@ RUN \
mv ./libcrypto.so.1.0.0 /tmp/ mv ./libcrypto.so.1.0.0 /tmp/
RUN strip /tmp/libcrypto.so.1.0.0 RUN strip /tmp/libcrypto.so.1.0.0
# Build numpy and salsa20 python module # Build python module (numpy salsa20 psutil)
FROM python:3.10-alpine3.16 AS salsa20 FROM python:3.10-alpine3.16 AS python-pkg
RUN apk add build-base linux-headers
RUN \ RUN \
apk add build-base && \ pip3 install numpy salsa20 psutil && \
pip3 install numpy salsa20 && \
cd /usr/local/lib/python*/site-packages/ && \ cd /usr/local/lib/python*/site-packages/ && \
mkdir /packages/ && mv ./*numpy* ./*salsa20* /packages/ && \ mkdir /site-packages/ && mv ./*numpy* ./*salsa20* ./psutil* /site-packages/ && \
rm -rf $(find /packages/ -name '__pycache__') rm -rf $(find /site-packages/ -name '__pycache__')
# Combine shadowsocks dependencies
FROM python:3.10-alpine3.16 AS shadowsocks
COPY --from=ss-rust /tmp/ss-rust-* /release/
COPY --from=ss-libev /tmp/ss-libev-* /release/
COPY --from=ss-python /packages/ /site-packages/ COPY --from=ss-python /packages/ /site-packages/
COPY --from=ss-bootstrap /tmp/ss-bootstrap-* /release/ RUN BZIP2=-9 tar czf /packages.tar.gz ./site-packages/
COPY --from=openssl /tmp/libcrypto.so* /release/
COPY --from=salsa20 /packages/ /site-packages/
RUN \
PYTHON_PACKAGE="/usr/local/lib/$(ls /usr/local/lib/ | grep ^python)/site-packages" && \
ln -s ${PYTHON_PACKAGE}/ssr-python/local.py /release/ssr-local && \
ln -s ${PYTHON_PACKAGE}/ssr-python/server.py /release/ssr-server && \
ln -s ${PYTHON_PACKAGE}/ss-python/local.py /release/ss-python-local && \
ln -s ${PYTHON_PACKAGE}/ss-python/server.py /release/ss-python-server && \
ln -s ${PYTHON_PACKAGE}/ss-python-legacy/local.py /release/ss-python-legacy-local && \
ln -s ${PYTHON_PACKAGE}/ss-python-legacy/server.py /release/ss-python-legacy-server && \
BZIP2=-9 tar cjf /release/packages.tar.bz2 ./site-packages/
# Compile sip003 plugins (part1 -> gcc & cargo) # Compile sip003 plugins (part1 -> gcc & cargo)
FROM rust:1.62-alpine3.16 AS plugin-1 FROM rust:1.62-alpine3.16 AS plugin-1
@ -443,32 +441,31 @@ RUN upx -9 /tmp/dnsproxy
# Combine all release # Combine all release
FROM python:3.10-alpine3.16 AS asset FROM python:3.10-alpine3.16 AS asset
COPY --from=shadowsocks /release/ /release/ COPY --from=python-pkg /packages.tar.gz /
COPY --from=plugin /release/ /release/
COPY --from=v2ray /tmp/v2* /release/
COPY --from=xray /tmp/xray /release/
COPY --from=trojan /tmp/trojan* /release/
COPY --from=gost /tmp/gost* /release/
COPY --from=brook /tmp/brook /release/
COPY --from=clash /tmp/clash /release/
COPY --from=snell /tmp/snell-* /release/
COPY --from=hysteria /tmp/hysteria /release/
COPY --from=naiveproxy /tmp/caddy /release/
COPY --from=naiveproxy /tmp/naive /release/
COPY --from=relaybaton /tmp/relaybaton /release/
COPY --from=pingtunnel /tmp/pingtunnel /release/
COPY --from=wireproxy /tmp/wireproxy /release/
COPY --from=dnsproxy /tmp/dnsproxy /release/
RUN \ RUN \
PACKAGE_DIR="/asset/usr/local/lib/$(ls /usr/local/lib/ | grep ^python)" && \ PACKAGE_DIR="/asset/usr/local/lib/$(ls /usr/local/lib/ | grep ^python)" && \
mkdir -p ${PACKAGE_DIR}/ && tar xf /release/packages.tar.bz2 -C ${PACKAGE_DIR}/ && \ mkdir -p ${PACKAGE_DIR}/ && tar xf /packages.tar.gz -C ${PACKAGE_DIR}/
mkdir -p /asset/lib/ && mv /release/*.so* /asset/lib/ && \ COPY --from=openssl /tmp/libcrypto.so* /asset/lib/
rm -f /release/packages.tar.bz2 && \ COPY --from=shadowsocks /release/ /asset/usr/bin/
mv /release/ /asset/usr/bin/ COPY --from=plugin /release/ /asset/usr/bin/
COPY --from=v2ray /tmp/v2* /asset/usr/bin/
COPY --from=xray /tmp/xray /asset/usr/bin/
COPY --from=trojan /tmp/trojan* /asset/usr/bin/
COPY --from=gost /tmp/gost* /asset/usr/bin/
COPY --from=brook /tmp/brook /asset/usr/bin/
COPY --from=clash /tmp/clash /asset/usr/bin/
COPY --from=snell /tmp/snell-* /asset/usr/bin/
COPY --from=hysteria /tmp/hysteria /asset/usr/bin/
COPY --from=naiveproxy /tmp/caddy /asset/usr/bin/
COPY --from=naiveproxy /tmp/naive /asset/usr/bin/
COPY --from=relaybaton /tmp/relaybaton /asset/usr/bin/
COPY --from=pingtunnel /tmp/pingtunnel /asset/usr/bin/
COPY --from=wireproxy /tmp/wireproxy /asset/usr/bin/
COPY --from=dnsproxy /tmp/dnsproxy /asset/usr/bin/
# Release docker image # Release docker image
FROM python:3.10-alpine3.16 FROM python:3.10-alpine3.16
COPY --from=asset /asset /
RUN \ RUN \
apk add --no-cache boost-program_options c-ares glib libev libsodium libstdc++ mbedtls pcre && \ apk add --no-cache boost-program_options c-ares glib libev libsodium libstdc++ mbedtls pcre && \
pip3 --no-cache-dir install colorlog pysocks requests pip3 --no-cache-dir install colorlog pysocks requests
COPY --from=asset /asset /

3
test.py

@ -5,10 +5,11 @@ import time
import requests import requests
from Tester import Shadowsocks from Tester import Shadowsocks
from Basis.Logger import logging from Basis.Logger import logging
from Basis.Functions import networkStatus
def test(testObj: dict) -> None: def test(testObj: dict) -> None:
logging.warning(testObj['title']) logging.warning(testObj['title'])
logging.debug('network status -> %s' % networkStatus())
testObj['client'].start() testObj['client'].start()
testObj['server'].start() testObj['server'].start()

Loading…
Cancel
Save