feat(脚本): 增加初始化ssh GCP脚本、完善一键脚本
parent
e44b5399b7
commit
89c772bd01
|
@ -2,7 +2,7 @@
|
||||||
# * Official English Documentation: http://nginx.org/en/docs/
|
# * Official English Documentation: http://nginx.org/en/docs/
|
||||||
# * Official Russian Documentation: http://nginx.org/ru/docs/
|
# * Official Russian Documentation: http://nginx.org/ru/docs/
|
||||||
|
|
||||||
user root;
|
user nginx;
|
||||||
worker_processes auto;
|
worker_processes auto;
|
||||||
error_log /var/log/nginx/error.log;
|
error_log /var/log/nginx/error.log;
|
||||||
pid /run/nginx.pid;
|
pid /run/nginx.pid;
|
||||||
|
@ -27,7 +27,7 @@ http {
|
||||||
keepalive_timeout 65;
|
keepalive_timeout 65;
|
||||||
types_hash_max_size 2048;
|
types_hash_max_size 2048;
|
||||||
|
|
||||||
# include /etc/nginx/mime.types;
|
include /etc/nginx/mime.types;
|
||||||
default_type application/octet-stream;
|
default_type application/octet-stream;
|
||||||
|
|
||||||
# Load modular configuration files from the /etc/nginx/conf.d directory.
|
# Load modular configuration files from the /etc/nginx/conf.d directory.
|
||||||
|
@ -38,7 +38,7 @@ http {
|
||||||
server {
|
server {
|
||||||
listen 80;
|
listen 80;
|
||||||
listen [::]:80;
|
listen [::]:80;
|
||||||
server_name domain; # 这里需要修改为你的
|
server_name ls.xxx.xyz; # 这里需要修改为你的
|
||||||
root /usr/share/nginx/html;
|
root /usr/share/nginx/html;
|
||||||
|
|
||||||
# Load configuration files for the default server block.
|
# Load configuration files for the default server block.
|
||||||
|
@ -57,17 +57,32 @@ http {
|
||||||
location = /50x.html {
|
location = /50x.html {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#server {
|
||||||
|
# listen 80;
|
||||||
|
# server_name ls.xxx.xyz;
|
||||||
|
# return 301 https://$host$request_uri;
|
||||||
|
#}
|
||||||
server {
|
server {
|
||||||
listen 443 ssl;
|
listen 443 ssl;
|
||||||
# ssl_certificate /etc/nginx/$1.crt;
|
# ssl_certificate /etc/nginx/ls.xx.xyz.crt;
|
||||||
# ssl_certificate_key /etc/nginx/$1.key;
|
# ssl_certificate_key /etc/nginx/ls.xx.xyz.key;
|
||||||
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
|
# ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
|
||||||
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
|
# ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
|
||||||
ssl_prefer_server_ciphers on;
|
# ssl_prefer_server_ciphers on;
|
||||||
server_name $1; # 这里需要修改
|
server_name ls.xxx.xyz; # 这里需要修改
|
||||||
location / {
|
location / {
|
||||||
}
|
}
|
||||||
location /alone {proxy_redirect off;proxy_pass http://127.0.0.1:31299;proxy_http_version 1.1;proxy_set_header Upgrade $http_upgrade;proxy_set_header Connection "upgrade";proxy_set_header X-Real-IP $remote_addr;proxy_set_header Host $host;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;}
|
location /v2 {
|
||||||
|
proxy_redirect off;
|
||||||
|
proxy_pass http://127.0.0.1:31290;
|
||||||
|
proxy_http_version 1.1;
|
||||||
|
proxy_set_header Upgrade $http_upgrade;
|
||||||
|
proxy_set_header Connection "upgrade";
|
||||||
|
# proxy_set_header Host $http_host;
|
||||||
|
proxy_set_header X-Real-IP $remote_addr;
|
||||||
|
proxy_set_header Host $host;
|
||||||
|
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,3 +15,4 @@ then
|
||||||
sed -i "${deleteLine}d" /etc/ssh/sshd_config
|
sed -i "${deleteLine}d" /etc/ssh/sshd_config
|
||||||
fi
|
fi
|
||||||
service sshd restart
|
service sshd restart
|
||||||
|
# echo '' >> ~/.ssh/authorized_keys
|
113
install.sh
113
install.sh
|
@ -1,7 +1,7 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
installType='yum -y install'
|
installType='yum -y install'
|
||||||
remove='yum -y remove'
|
removeType='yum -y remove'
|
||||||
upgrade="yum -y update"
|
upgrade="yum -y update"
|
||||||
echoType='echo -e'
|
echoType='echo -e'
|
||||||
|
|
||||||
|
@ -36,7 +36,13 @@ echoContent(){
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
fixBug(){
|
||||||
|
if [[ "${release}" = "ubuntu" ]]
|
||||||
|
then
|
||||||
|
cd /var/lib/dpkg/
|
||||||
|
|
||||||
|
fi
|
||||||
|
}
|
||||||
# 安装工具包
|
# 安装工具包
|
||||||
installTools(){
|
installTools(){
|
||||||
# echo "export LC_ALL=en_US.UTF-8" >> /etc/profile
|
# echo "export LC_ALL=en_US.UTF-8" >> /etc/profile
|
||||||
|
@ -48,7 +54,14 @@ installTools(){
|
||||||
then
|
then
|
||||||
nginx -s stop
|
nginx -s stop
|
||||||
fi
|
fi
|
||||||
removeLog=`yum remove nginx -y`
|
|
||||||
|
if [[ "${release}" = "ubuntu" ]] || [[ "${release}" = "debian" ]]
|
||||||
|
then
|
||||||
|
dpkg --get-selections | grep nginx|awk '{print $1}'|xargs sudo apt --purge remove -y > /dev/null
|
||||||
|
else
|
||||||
|
removeLog=`${removeType} nginx`
|
||||||
|
fi
|
||||||
|
rm -rf /etc/nginx/nginx.conf
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ ! -z `find /usr/bin/ -name "v2ray*"` ]]
|
if [[ ! -z `find /usr/bin/ -name "v2ray*"` ]]
|
||||||
|
@ -96,7 +109,12 @@ installTools(){
|
||||||
|
|
||||||
echoContent yellow "检查、安装crontabs--->"
|
echoContent yellow "检查、安装crontabs--->"
|
||||||
progressTool crontabs &
|
progressTool crontabs &
|
||||||
|
if [[ "${release}" = "ubuntu" ]]
|
||||||
|
then
|
||||||
|
${installType} cron > /dev/null
|
||||||
|
else
|
||||||
${installType} crontabs > /dev/null
|
${installType} crontabs > /dev/null
|
||||||
|
fi
|
||||||
|
|
||||||
echoContent yellow "检查、安装jq--->"
|
echoContent yellow "检查、安装jq--->"
|
||||||
progressTool jq &
|
progressTool jq &
|
||||||
|
@ -111,6 +129,7 @@ installTools(){
|
||||||
installNginx(){
|
installNginx(){
|
||||||
echoContent skyBlue "检查、安装Nginx、TLS:"
|
echoContent skyBlue "检查、安装Nginx、TLS:"
|
||||||
echoContent yellow "请输入要配置的域名 例:worker.v2ray-agent.com --->"
|
echoContent yellow "请输入要配置的域名 例:worker.v2ray-agent.com --->"
|
||||||
|
rm -rf /etc/nginx/nginx.conf
|
||||||
read domain
|
read domain
|
||||||
if [[ -z ${domain} ]]
|
if [[ -z ${domain} ]]
|
||||||
then
|
then
|
||||||
|
@ -122,17 +141,28 @@ installNginx(){
|
||||||
progressTool nginx &
|
progressTool nginx &
|
||||||
${installType} nginx > /dev/null
|
${installType} nginx > /dev/null
|
||||||
|
|
||||||
|
if [[ ! -z `ps -ef|grep -v grep|grep nginx` ]]
|
||||||
|
then
|
||||||
|
nginx -s stop
|
||||||
|
fi
|
||||||
|
|
||||||
# 修改配置
|
# 修改配置
|
||||||
echoContent yellow "修改配置文件--->"
|
echoContent yellow "修改配置文件--->"
|
||||||
installLine=`cat /etc/nginx/nginx.conf|grep -n root|awk -F "[:]" '{print $1+1}'|head -1`
|
|
||||||
sed -i "${installLine}i location ~ /.well-known {allow all;}" /etc/nginx/nginx.conf
|
|
||||||
installLine=`expr ${installLine} + 1`
|
touch /etc/nginx/conf.d/alone.conf
|
||||||
sed -i "${installLine}i location /test {return 200 'fjkvymb6len';}" /etc/nginx/nginx.conf
|
# installLine=`cat /etc/nginx/nginx.conf|grep -n root|awk -F "[:]" '{print $1+1}'|head -1`
|
||||||
|
# ${installLine}
|
||||||
|
# ${domain}
|
||||||
|
echo "server {listen 80;server_name ${domain};root /usr/share/nginx/html;location ~ /.well-known {allow all;}location /test {return 200 'fjkvymb6len';}}" > /etc/nginx/conf.d/alone.conf
|
||||||
|
# sed -i "1i 1" /etc/nginx/conf.d/alone.conf
|
||||||
|
# installLine=`expr ${installLine} + 1`
|
||||||
|
# sed -i "${installLine}i location /test {return 200 'fjkvymb6len';}" /etc/nginx/nginx.conf
|
||||||
# 启动nginx
|
# 启动nginx
|
||||||
nginx
|
nginx
|
||||||
|
|
||||||
# 测试nginx
|
# 测试nginx
|
||||||
echoContent yellow "检查Nginx是否正常访问--->"
|
echoContent yellow "检查Nginx是否正常访问,请等待--->"
|
||||||
# ${domain}
|
# ${domain}
|
||||||
domainResult=`curl -s ${domain}/test|grep fjkvymb6len`
|
domainResult=`curl -s ${domain}/test|grep fjkvymb6len`
|
||||||
if [[ ! -z ${domainResult} ]]
|
if [[ ! -z ${domainResult} ]]
|
||||||
|
@ -156,7 +186,7 @@ installTLS(){
|
||||||
echoContent yellow " 安装acme--->"
|
echoContent yellow " 安装acme--->"
|
||||||
curl -s https://get.acme.sh | sh >/dev/null
|
curl -s https://get.acme.sh | sh >/dev/null
|
||||||
echoContent green " acme安装完毕--->"
|
echoContent green " acme安装完毕--->"
|
||||||
echoContent yellow " 生成TLS证书中,请等待--->"
|
echoContent yellow "生成TLS证书中,请等待--->"
|
||||||
sudo ~/.acme.sh/acme.sh --issue -d $1 --standalone -k ec-256 >/dev/null
|
sudo ~/.acme.sh/acme.sh --issue -d $1 --standalone -k ec-256 >/dev/null
|
||||||
~/.acme.sh/acme.sh --installcert -d $1 --fullchainpath /etc/nginx/$1.crt --keypath /etc/nginx/$1.key --ecc >/dev/null
|
~/.acme.sh/acme.sh --installcert -d $1 --fullchainpath /etc/nginx/$1.crt --keypath /etc/nginx/$1.key --ecc >/dev/null
|
||||||
if [[ -z `cat /etc/nginx/$1.crt` ]]
|
if [[ -z `cat /etc/nginx/$1.crt` ]]
|
||||||
|
@ -184,8 +214,9 @@ installTLS(){
|
||||||
cp -R /tmp/tls/$1.key /etc/nginx/$1.key
|
cp -R /tmp/tls/$1.key /etc/nginx/$1.key
|
||||||
fi
|
fi
|
||||||
|
|
||||||
nginxInstallLine=`cat /etc/nginx/nginx.conf|grep -n "}"|awk -F "[:]" 'END{print $1-1}'`
|
# nginxInstallLine=`cat /etc/nginx/nginx.conf|grep -n "}"|awk -F "[:]" 'END{print $1-1}'`
|
||||||
sed -i "${nginxInstallLine}i server {listen 443 ssl;server_name $1;root /usr/share/nginx/html;ssl_certificate /etc/nginx/$1.crt;ssl_certificate_key /etc/nginx/$1.key;ssl_protocols TLSv1 TLSv1.1 TLSv1.2;ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;ssl_prefer_server_ciphers on;location / {} location /alone { proxy_redirect off;proxy_pass http://127.0.0.1:31299;proxy_http_version 1.1;proxy_set_header Upgrade \$http_upgrade;proxy_set_header Connection "upgrade";proxy_set_header X-Real-IP \$remote_addr;proxy_set_header Host \$host;proxy_set_header X-Forwarded-For \$proxy_add_x_forwarded_for;}}" /etc/nginx/nginx.conf
|
# sed -i "${nginxInstallLine}i server {listen 443 ssl;server_name $1;root /usr/share/nginx/html;ssl_certificate /etc/nginx/$1.crt;ssl_certificate_key /etc/nginx/$1.key;ssl_protocols TLSv1 TLSv1.1 TLSv1.2;ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;ssl_prefer_server_ciphers on;location / {} location /alone { proxy_redirect off;proxy_pass http://127.0.0.1:31299;proxy_http_version 1.1;proxy_set_header Upgrade \$http_upgrade;proxy_set_header Connection "upgrade";proxy_set_header X-Real-IP \$remote_addr;proxy_set_header Host \$host;proxy_set_header X-Forwarded-For \$proxy_add_x_forwarded_for;}}" /etc/nginx/nginx.conf
|
||||||
|
echo "server {listen 443 ssl;server_name $1;root /usr/share/nginx/html;ssl_certificate /etc/nginx/$1.crt;ssl_certificate_key /etc/nginx/$1.key;ssl_protocols TLSv1 TLSv1.1 TLSv1.2;ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;ssl_prefer_server_ciphers on;location / {} location /alone { proxy_redirect off;proxy_pass http://127.0.0.1:31299;proxy_http_version 1.1;proxy_set_header Upgrade \$http_upgrade;proxy_set_header Connection "upgrade";proxy_set_header X-Real-IP \$remote_addr;proxy_set_header Host \$host;proxy_set_header X-Forwarded-For \$proxy_add_x_forwarded_for;}}" > /etc/nginx/conf.d/alone.conf
|
||||||
nginx
|
nginx
|
||||||
if [[ -z `ps -ef|grep -v grep|grep nginx` ]]
|
if [[ -z `ps -ef|grep -v grep|grep nginx` ]]
|
||||||
then
|
then
|
||||||
|
@ -227,6 +258,10 @@ installV2Ray(){
|
||||||
exit 0;
|
exit 0;
|
||||||
fi
|
fi
|
||||||
echoContent green " V2Ray启动成功--->"
|
echoContent green " V2Ray启动成功--->"
|
||||||
|
echoContent yellow "V2Ray日志目录:"
|
||||||
|
echoContent green " access: /tmp/v2ray/v2ray_access_ws_tls.log"
|
||||||
|
echoContent green " error: /tmp/v2ray/v2ray_error_ws_tls.log"
|
||||||
|
|
||||||
# 验证整个服务是否可用
|
# 验证整个服务是否可用
|
||||||
echoContent yellow "验证服务是否可用--->"
|
echoContent yellow "验证服务是否可用--->"
|
||||||
if [[ `curl -s -L https://$1/alone` = "Bad Request" ]]
|
if [[ `curl -s -L https://$1/alone` = "Bad Request" ]]
|
||||||
|
@ -282,7 +317,7 @@ qrEncode(){
|
||||||
path=`echo ${user}|jq .streamSettings.wsSettings.path`
|
path=`echo ${user}|jq .streamSettings.wsSettings.path`
|
||||||
qrCodeBase64=`echo -n '{"port":"443","ps":"'${ps}'","tls":"tls","id":'"${id}"',"aid":"64","v":"2","host":"'${host}'","type":"none","path":'${path}',"net":"ws","add":"'${host}'"}'|sed 's#/#\\\/#g'|base64`
|
qrCodeBase64=`echo -n '{"port":"443","ps":"'${ps}'","tls":"tls","id":'"${id}"',"aid":"64","v":"2","host":"'${host}'","type":"none","path":'${path}',"net":"ws","add":"'${host}'"}'|sed 's#/#\\\/#g'|base64`
|
||||||
qrCodeBase64=`echo ${qrCodeBase64}|sed 's/ //g'`
|
qrCodeBase64=`echo ${qrCodeBase64}|sed 's/ //g'`
|
||||||
echoContent yellow " 通用链接--->"
|
echoContent green " 通用链接--->"
|
||||||
echoContent green vmess://${qrCodeBase64}
|
echoContent green vmess://${qrCodeBase64}
|
||||||
# | qrencode -t UTF8
|
# | qrencode -t UTF8
|
||||||
# echo ${qrCodeBase64}
|
# echo ${qrCodeBase64}
|
||||||
|
@ -346,44 +381,34 @@ init(){
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
checkSystem(){
|
checkSystem(){
|
||||||
if [ -f /etc/redhat-release ]; then
|
|
||||||
|
if [[ ! -z `find /etc -name "redhat-release"` ]] || [[ ! -z `cat /proc/version | grep -i "centos" | grep -v grep ` ]] || [[ ! -z `cat /proc/version | grep -i "red hat" | grep -v grep ` ]] || [[ ! -z `cat /proc/version | grep -i "redhat" | grep -v grep ` ]]
|
||||||
|
then
|
||||||
release="centos"
|
release="centos"
|
||||||
installTool='yum -y'
|
installType='yum -y install'
|
||||||
echoType='echo -e'
|
|
||||||
removeType='yum -y remove'
|
removeType='yum -y remove'
|
||||||
elif cat /etc/issue | grep -q -E -i "debian"; then
|
upgrade="yum update -y"
|
||||||
|
elif [[ ! -z `cat /etc/issue | grep -i "debian" | grep -v grep` ]] || [[ ! -z `cat /proc/version | grep -i "debian" | grep -v grep` ]]
|
||||||
|
then
|
||||||
release="debian"
|
release="debian"
|
||||||
installTools='apt'
|
installType='apt -y install'
|
||||||
echoType='echo -e'
|
upgrade="apt update -y"
|
||||||
removeType='apt -y autoremove'
|
removeType='apt -y autoremove'
|
||||||
elif cat /etc/issue | grep -q -E -i "ubuntu"; then
|
elif [[ ! -z `cat /etc/issue | grep -i "ubuntu" | grep -v grep` ]] || [[ ! -z `cat /proc/version | grep -i "ubuntu" | grep -v grep` ]]
|
||||||
|
then
|
||||||
release="ubuntu"
|
release="ubuntu"
|
||||||
installTools='apt'
|
installType='apt -y install'
|
||||||
echoType='echo -e'
|
upgrade="apt update -y"
|
||||||
removeType='apt -y autoremove'
|
removeType='apt --purge remove'
|
||||||
elif cat /etc/issue | grep -q -E -i "centos|red hat|redhat"; then
|
|
||||||
release="centos"
|
fi
|
||||||
installTools='yum'
|
if [[ -z ${release} ]]
|
||||||
echoType='echo -e'
|
then
|
||||||
removeType='yum -y remove'
|
echoContent red "本脚本不支持此系统,请将下方日志反馈给开发者"
|
||||||
elif cat /proc/version | grep -q -E -i "debian"; then
|
cat /etc/issue
|
||||||
release="debian"
|
cat /proc/version
|
||||||
installTools='apt'
|
exit 0;
|
||||||
removeType='apt -y autoremove'
|
|
||||||
echoType='echo -e'
|
|
||||||
elif cat /proc/version | grep -q -E -i "ubuntu"; then
|
|
||||||
release="ubuntu"
|
|
||||||
installTools='apt'
|
|
||||||
removeType='apt -y autoremove'
|
|
||||||
echoType='echo -e'
|
|
||||||
elif cat /proc/version | grep -q -E -i "centos|red hat|redhat"; then
|
|
||||||
release="centos"
|
|
||||||
installTools='yum'
|
|
||||||
removeType='yum -y remove'
|
|
||||||
echoType='echo -e'
|
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
#checkSystem
|
checkSystem
|
||||||
#[ ${release} != "debian" ] && [ ${release} != "ubuntu" ] && [ ${release} != "centos" ] && ${echoType} "${Error} 本脚本不支持当前系统 ${release} !" && exit 1
|
|
||||||
init
|
init
|
||||||
#progressTool
|
|
||||||
|
|
Loading…
Reference in New Issue