使用阿里云 ECS 实现持续集成集成 Node.js with Typescript 应用

OS: CentOS 7.3 64位

目标: 使用 Jenkins + Docker 构建一个持续集成系统,并完成部署使用 Typescript 编写的 Node.js 项目,使用 nginx 进行反向代理,在外网能够使用域名直接访问。

注意⚠️ 以下所有操作均未使用 root 账户直接操作,故代码中包含大量 sudo

一、 安装/启动 docker & Jenkins

#1 更新 yum 源

sudo yum update

#2 安装 docker(Jenkins 依赖于 docker)

sudo yum install docker

#3 启动 docker,并设置为开机启动

sudo service docker start

sudo chkconfig docker on

#4 安装 Jenkins

sudo docker pull jenkins:latest

jenkins:latest 中的 latest 类似于 npm 中的 label,在这个命令中获取了最新版本的 Jenkins,如果需要指定版本只需替换该单词为具体的版本号就可以了。

#5 构建自定义的Jenkins镜像

    1. 执行 mkdir src && cd src && mkdir myjenkins && cd myjenkins 命令创建自定义的Jenkins目录并进入
    1. vi dockerfile 创建docker配置文件
    1. 输入以下内容并保存
FROM jenkins:latest

USER root
RUN apt-get update \
  && apt-get install -y sudo \
  && rm -rf /var/lib/apt/lists/*
RUN echo "jenkins ALL=NOPASSWD: ALL" >> /etc/sudoers
    1. sudo docker build -t myjenkins 构建镜像,并命名为 myjenkins

#6 启动 Jenkins

首先需要在 /var/ 下创建一个挂载 Jenkins 日志的目录,命名为 jenkins_home (如果是
root 账户可以无视 sudo

sudo mkdir /var/jenkins_home

然后运行 myjenkins 镜像

sudo docker run -d --name myjenkins -p 49002:8080 \
                -v /var/run/docker.sock:/var/run/docker.sock \
                -v $(which docker):/usr/bin/docker \
                -v /var/jenkins_home:/var/jenkins_home myjenkins

这句命令的意思是:在后台运行一个基于 jenkins:latest 镜像的容器, 容器的 name 为 myjenkins ,并且将容器的8080端口映射到服务器上的49002端口,同时将服务器上的 /var/jenkins_home (目录名可自取)挂载到容器的 /var/jenkins_home 目录上。

  • -d 后台运行docker容器
    如果不加-d则,容器运行会占用此终端,如果终端关闭,则容器也相应关闭,jenkins就无法访问了。加上-d,容器会在后台运行。
  • --name 为容器起个别名
    如果不起别名,则系统会默认分配一个随机别名,类似gklasd_sdfwe。起了别名后,后续会通过该别名管理该docker容器,也就是管理jenkins。
  • -p docker容器端口映射
    jenkins服务是运行在docker里的,docker默认不对外暴露端口的
  • -v 文件挂载
    如果不挂载,则jenkins所有log、用户配置文件都会在docker容器内,如果容器销毁,则jenkins得重新配置一遍。挂载出来方便jenkins迁移以及管理
运行成功

二、配置 nginx 反向代理使用公网域名访问 Jenkins 服务

在跟着第一部分走完之后,直接访问 ip:49002 会发现无法访问 Jenkins 服务。这是因为阿里云 ECS 的安全组策略阻止了该端口的公网访问权限,可以通过修改安全策略解决,但是考虑到访问的便利性,我决定使用 nginx 反向代理至域名的方式使 Jenkins 服务暴露在公网中。(3,4可略过,即从不修改安全组策略)

#1 安装 nginx

sudo yum install nginx

#2 启动 nginx

sudo systemctl enable nginx

systemctl start nginx

如果中间没有报错,此时访问服务器的 IP (需开放 80 接口)就会看到 nginx 的 test 界面了。

#3 使用 IP 访问 Jenkins 服务(开放 49002 端口安全策略),使用初始密码解锁

Jenkins 服务

// 进入容器
sudo docker exec -it myjenkins bash

// 获取初始密码
cat /var/jenkins_home/secrets/initialAdminPassword

如果无法访问服务,请打开 /var/jenkins_home 目录的读写权限。

#4 根据向导安装插件

Jenkins 欢迎界面

#5 配置 nginx 反向代理 Jenkins 服务

执行 vi /etc/nginx/conf.d/jenkins.conf 修改 nginx 配置文件如下,即可将服务器上的 49002 端口反向代理至 web 服务器:

nginx configuration

修改完毕后执行 service nginx restart 重启 nginx 服务

#6 在域名服务商中添加一条 A 记录的解析设置

image.png

Tada!

通过 jenkins.dogrod.com 访问 Jenkins 服务

Tips

~/.ssh/config (MacOS) 中添加 ServerAliveInterval 60 可防止 ssh 因超时被拒绝访问。

Reference

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,117评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,328评论 1 293
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,839评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,007评论 0 206
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,384评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,629评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,880评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,593评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,313评论 1 243
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,575评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,066评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,392评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,052评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,082评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,844评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,662评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,575评论 2 270

推荐阅读更多精彩内容