shell脚本发布docker-nginx vue2 项目示例

docker、git、node.js安装略过。
使git pull或者git push不需要输入密码操作方法
nginx安装在docker容器里面,参见https://blog.csdn.net/HSJ0170/article/details/128631155

姊妹篇(宿主机nginx,非docker-nginx):shell脚本发布nginx vue2 项目示例

pro_build.sh
注意:#!/bin/bash -ilex,如果jenkins远程ssh登录执行sh脚本,并且jekins安装在docker容器里面,这句代码很有必要。
在这里插入图片描述

#!/bin/bash
who am i
set -e
#当前vue2demo目录
cd /opt/vue2demo

echo "拉取gitlib最新代码..."
git status && git pull

#if判断其实是多余的,set -e 当$? 不等于0时候已经退出了
if [[ $? -ne 0 ]]
then
  echo "拉取gitlib最新代码失败,准备退出"
  exit 1
fi
echo "拉取gitlib最新代码成功"

rm -rf dist/
rm -rf /opt/nginx_volume_data/html/vue2demo/dist/
echo "删除旧的dist打包目录、vue2demo/dist/目录"

echo "npm install --> 准备安装依赖..."
npm install

echo "npm run build --> 准备构建打包..."
npm run build

echo "准备发布到docker-nginx html 目录..."
mv dist/ /opt/nginx_volume_data/html/vue2demo/

echo "发布完毕"


nginx配置文件vue2demo.conf:
路径:/opt/nginx_volume_data/conf/conf.d
在这里插入图片描述

server {
        listen 8888;
        server_name  192.168.1.105;
        charset utf-8;       

        #proxy_intercept_errors on;
        
		#ui
		location / {
				root   /usr/share/nginx/html/vue2demo/dist;
				index  index.html index.htm;
		} 
		#serve 
		#服务springboot见文章:https://blog.csdn.net/HSJ0170/article/details/137103193
		location ^~/api {
			proxy_set_header   Host             $host;
			proxy_set_header   X-Real-IP        $remote_addr;
			proxy_set_header   X-Real-Port      $remote_port;
			proxy_set_header   X-Forwarded-Proto $scheme;
			proxy_set_header   X-Forwarded-For $proxy_add_x_forwarded_for;
			proxy_buffering off;
			rewrite ^/api/(.*)$ /$1 break;
			proxy_pass http://192.168.1.105:55530;
            #启用支持websocket连接
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection "upgrade";
		}
    }

启动:

#先删除docker-nginx容器
docker rm -f docker-nginx
#重新启动80,8888端口
docker run -p 80:80 -p 8888:8888 --name docker-nginx \
-v /opt/nginx_volume_data/html:/usr/share/nginx/html \
-v /opt/nginx_volume_data/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /opt/nginx_volume_data/conf/conf.d:/etc/nginx/conf.d \
-e TZ=Asia/Shanghai \
-d nginx

Docker-Nginx-RTMP是一个基于Docker容器Nginx RTMP服务器。你可以在Docker Hub的镜像页面上搜索关键词"nginx rtmp"来找到相关的镜像[1]。使用Docker可以方便地安装和部署Nginx RTMP服务器,而且在开发和测试过程中能避免许多安装和配置问题[2]。 为了在Docker中安装Nginx RTMP,你可以使用以下命令: ``` sudo docker run -d --name rtmp -p 1935:1935 -p 8080:8080 -v ~/Documents/nginx-1.19.2/conf/nginx.conf:/etc/nginx/nginx.conf alqutami/rtmp-hls ``` 这个命令将在Docker容器中运行一个名为"rtmp"的容器,并将主机的1935端口和8080端口映射到容器的对应端口。同时,使用-v参数来将本地目录`~/Documents/nginx-1.19.2/conf/nginx.conf`挂载到容器中的`/etc/nginx/nginx.conf`目录中,以便配置Nginx RTMP服务器。 通过上述步骤,你就可以在Docker中成功安装并运行Nginx RTMP服务器了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [docker 搭建nginx-rtmp](https://blog.csdn.net/chy555chy/article/details/109778101)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [docker安装nginx+rtmp模块搭建服务器实现ffmpeg推流+ffplay播放](https://blog.csdn.net/lwwl12/article/details/104903403)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值