nginx_shell脚本扩展配置虚拟主机三种方式

#需要注意的是

代理proxy_pass http://192.168.29.188:5000; 我这里使用的是容器中的flask地址

bash 复制代码
#!/bin/bash

# 1. 查看当前系统 nginx 配置文件位置
nginxconf_path=$(whereis nginx | awk '{print $2}')/conf/nginx.conf
echo "nginxconf_path: $nginxconf_path"

# 2. 查看主配置文件是否有导入扩展配置文件的指令
if grep -q "include /usr/local/nginx/conf/conf.d/*.conf;" $nginxconf_path; then
    echo "Import extended configuration: /usr/local/nginx/conf/conf.d/*.conf"
else
    echo "No import extended configuration"
    # 2.1. 若没有,则需要在主配置文件中添加 include /usr/local/nginx/conf/conf.d/*.conf;
    sudo sed -i '/http {/a include /usr/local/nginx/conf/conf.d/*.conf;' $nginxconf_path
    echo "Added import extended configuration: /usr/local/nginx/conf/conf.d/*.conf"
fi

# 3. 查看扩展配置文件目录是否存在
if [ -d "/usr/local/nginx/conf/conf.d" ]; then
    echo "Extended configuration directory exists"
else
    echo "Extended configuration directory does not exist"
    # 3.1. 若不存在,则需要创建扩展配置文件目录
    sudo mkdir -p /usr/local/nginx/conf/conf.d
    echo "Created extended configuration directory"
fi

# 4. 定义配置文件名数组
conf_files=("domain.conf" "ip.conf" "port.conf")

# 5. 检查并创建配置文件
for file in "${conf_files[@]}"; do
    if [ -f "/usr/local/nginx/conf/conf.d/$file" ]; then
        echo "Extended configuration file exists: $file"
    else
        echo "Extended configuration file does not exist: $file"
        # 5.1. 若不存在,则需要创建扩展配置文件
        echo "Creating extended configuration file: $file"
        sudo touch "/usr/local/nginx/conf/conf.d/$file"
    fi
done

# 6. 定义函数来写入配置文件
write_config() {
    local file_path=$1
    local server_name=$2
    local listen_port=$3

    cat <<EOF | sudo tee "$file_path" > /dev/null
server {
    listen $listen_port;
    server_name $server_name;
    location / {
        # 代理转发到我的docker中的flask项目
        proxy_pass http://192.168.29.188:5000;
    }
}
EOF
}

# 7. 交互式选择配置
echo "Select virtual host configuration type:"
select conf_type in "IP" "Domain" "Port" "Quit"; do
    echo "You selected: $conf_type"  # 调试输出
    case "$conf_type" in
        "Domain") 
            write_config "/usr/local/nginx/conf/conf.d/${conf_files[0]}" "example.com" 80
            break
            ;;
        "IP") 
            write_config "/usr/local/nginx/conf/conf.d/${conf_files[1]}" "192.168.29.129" 80
            break
            ;;
        "Port") 
            write_config "/usr/local/nginx/conf/conf.d/${conf_files[2]}" "example.com" 9888
            break
            ;;
        "Quit") 
            exit 0
            ;;
        *) 
            echo "Invalid input. Please try again."
            ;;
    esac
done

# 8. 重启 nginx 服务并检查是否成功
if sudo systemctl restart nginx; then
    echo "Nginx service restarted successfully"
else
    echo "Failed to restart Nginx service"
    exit 1
fi
相关推荐
wanhengidc1 小时前
云手机在网络游戏中的主要功能
运维·服务器·游戏·智能手机
HitpointNetSuite2 小时前
连锁餐饮行业ERP如何选择:为何Oracle NetSuite成为增长新引擎
大数据·运维·数据库·oracle·netsuite
讲师-汪春波2 小时前
[运维]宝塔 Apache环境使用CDN获取访客真实IP方法
运维·tcp/ip·apache·cdn
2401_858286116 小时前
OS36.【Linux】简单理解EXT2文件系统(2)
linux·运维·服务器·数据结构·文件系统·ext2
勤源科技7 小时前
全链路智能运维中的业务连续性保障与容灾切换机制
运维
Zach_yuan7 小时前
程序地址空间
android·linux·运维·服务器
梁萌7 小时前
Linux安装BiliNote
linux·运维·服务器·docker·bilinote
小安运维日记7 小时前
RHCA - DO374 | Day03:通过自动化控制器运行剧本
linux·运维·数据库·自动化·ansible·1024程序员节
行思理8 小时前
docker新手教程
运维·docker·容器
TG_yunshuguoji9 小时前
亚马逊云渠道商:本地SSD缓存如何保障数据安全?
运维·服务器·安全·云计算·aws