Docker学习6:使用docker构建Jekyll服务和java服务

写在前面


## 文章Dockerfile中涉及apt-get 等操作需更换镜像 在Dockerfile中添加下列

Dockerfile源码,见下面作者github
https://github.com/turnbullpress/dockerbook-code/blob/master/code/6

RUN rm -rf /etc/apt/sources.list 

ADD sources.list /etc/apt/      

source.list 文件见下面链接  文件位置与Dockerfile文件在同一级目录下

deb http://mirrors.aliyun.com/ubuntu/ bionic main restricted universe multiverse 

deb http://mirrors.aliyun.com/ubuntu/ bionic-security main restricted universe multiverse 

deb http://mirrors.aliyun.com/ubuntu/ bionic-updates main restricted universe multiverse 

deb http://mirrors.aliyun.com/ubuntu/ bionic-proposed main restricted universe multiverse 

deb http://mirrors.aliyun.com/ubuntu/ bionic-backports main restricted universe multiverse 

deb-src http://mirrors.aliyun.com/ubuntu/ bionic main restricted universe multiverse 

deb-src http://mirrors.aliyun.com/ubuntu/ bionic-security main restricted universe multiverse 

deb-src http://mirrors.aliyun.com/ubuntu/ bionic-updates main restricted universe multiverse 

deb-src http://mirrors.aliyun.com/ubuntu/ bionic-proposed main restricted universe multiverse 

deb-src http://mirrors.aliyun.com/ubuntu/ bionic-backports main restricted universe multiverse 


1.构建第一个应用

构建2个镜像:

1、一个镜像安装Jekyll以及构建jekyll的软件包

2、通过Apache让Jekyll网站工作起来

工作流程:

1.创建Jekyll镜像和Apache镜像

2.从Jekyll镜像创建容器,通过卷挂载网站源代码

3.从Apache镜像创建容器,运行服务

4.在需要更新时,重复工作


具体步骤可借鉴下面博客

https://www.cnblogs.com/manmanchanglu/p/12000025.html



2.使用docker构建一个java服务

1.一个镜像从URL拉取指定war包文件保存到卷中

2.一个含有Tomcat服务器的镜像运行在这些下载的war文件中

2.1war文件获取程序

构建一个镜像会下载war文件,挂载到卷中

mkdir fetcher

cd fetcher

vim Dockerfile



构建镜像docker build -t jamtur01/fetcher .

2.2.获取war文件

docker run -t -i --name sample jamtur01/fetcher \

https://tomcat.apache.org/tomcat-7.0-doc/appdev/sample/sample.war


查看卷目录


2.3 Tomcat8应用服务器

## 更换镜像RUN rm-rf/etc/apt/sources.listADD sources.list/etc/apt/


vim Dockerfile

FROMubuntu:18.04

LABELmaintainer="james@example.com"

ENVREFRESHED_AT 2016-06-01

RUN apt-get -qq update

RUN apt-get -qq install tomcat8 default-jdk

ENVCATALINA_HOME /usr/share/tomcat8

ENVCATALINA_BASE /var/lib/tomcat8

ENVCATALINA_PID /var/run/tomcat8.pid

ENVCATALINA_SH /usr/share/tomcat8/bin/catalina.sh

ENVCATALINA_TMPDIR /tmp/tomcat8-tomcat8-tmp

RUNmkdir -p $CATALINA_TMPDIR

VOLUME["/var/lib/tomcat8/webapps/"]

EXPOSE8080

ENTRYPOINT["/usr/share/tomcat8/bin/catalina.sh","run"]

docker build -t jamtur01/tomcat8 .

2.4 运行WAR文件

创建tomcat8示例

docker run --name sample_app --volumes-from sample \

-d -P jamtur01/tomcat8

查看容器暴露的端口

docker port sample_app 8080

2.5基于tomcat应用服务器的构建服务

安装ruby

apt-get -qqy install ruby make ruby-dev

安装TProv应用

gem install --no-rdoc --no-ri tprov

tprov // 运行项目


会显示你运行的所有的容器

3.多容器应用栈

一个Node容器,用来服务于Node应用,这个容器会链接到。

一个Redis主容器,用于保存和集群化应用状态,这个容器会链接到。

两个Redis副本容器,用于集群化应用状态。

一个日志容器,用于捕获应用日志。

3.1Node.js镜像


创建dockerfile

wget https://github.com/turnbullpress/dockerbook-code/blob/master/code/6/node/nodejs/nodeapp/package.json

wget https://github.com/turnbullpress/dockerbook-code/blob/master/code/6/node/nodejs/nodeapp/server.js

cd ..

vim Dockerfile


FROM ubuntu:18.04

LABEL maintainer="james@example.com"

ENV REFRESHED_AT 2016-06-01

RUN apt-get -qq update

RUN apt-get -qq install nodejs npm

RUN mkdir -p /var/log/nodeapp

ADD nodeapp /opt/nodeapp/

WORKDIR /opt/nodeapp

RUN npm install

VOLUME ["/var/log/nodeapp"]

EXPOSE 3000

ENTRYPOINT ["nodejs","server.js"]


构建node.js镜像

docker build -t jamtur01/nodejs .

3.2 Redis基础镜像


FROMubuntu:18.04

LABELmaintainer="james@example.com"

ENVREFRESHED_AT 2017-06-01

RUNapt-get -qq update

RUNapt-get install -qq software-properties-common

RUNadd-apt-repository ppa:chris-lea/redis-server

RUNapt-get -qq update

RUNapt-get -qq install redis-server redis-tools

VOLUME["/var/lib/redis","/var/log/redis"]

EXPOSE6379

CMD[]

构建redis基础镜像 docker build -t jamtur01/redis .


3.3 Redis主镜像


FROMjamtur01/redis

LABELmaintainer="james@example.com"

ENVREFRESHED_AT 2016-06-01

ENTRYPOINT["redis-server","--protected-mode no","--logfile /var/log/redis/redis-server.log"]

构建Redis主镜像 docker build -t jamtur01/redis_primary .


3.4 Redis 副本镜像


FROMjamtur01/redis

LABELmaintainer="james@example.com"

ENVREFRESHED_AT 2016-06-01

ENTRYPOINT["redis-server","--protected-mode no","--logfile /var/log/redis/redis-replica.log","--slaveof redis_primary 6379"]

docker build -t jamtur01/redis_replica .


3.5 创建Redis后端集群

创建express网络

docker network create express

运行redis 主容器

docker run -d -h redis_primary \

--net express --name redis_primary jamtur01/redis_primary

-h 用来设置容器的主机名,可以确保redis_primary 作为主机名,并被本地DNS服务正确解析

redis容器日志

docker logs redis_primary

看不到日志。 redis服务会将日志保存成文件,使用docker看不到日志,可以使用之前看到的 /var/log/redis 卷。

读取redis主日志

docker run -ti --rm --volume-from redis_primary \

ubuntu cat /var/log/redis/redis-server.log

运行第一个redis容器副本

docker run -d -h redis_replica1 \

--name redis_replica1 \

--net express \

jamtur01/redis_replica

读取redis副本容器日志

docker run -ti --volumes-from redis_replica1 \

ubuntu cat /var/log/redis/redis-replica.log


运行第二个redis容器副本

docker run -d -h redis_replica2 \

--name redis_replica2 \

--net express \

jamtur01/redis_replica

读取redis副本容器日志

docker run -ti --volumes-from redis_replica2 \

ubuntu cat /var/log/redis/redis-replica.log



3.6创建Node容器

运行Node.js容器

docker run -d \

--name nodeapp -p 3000:3000 \

--net express \

jamtur01/nodejs

查看nodeapp容器日志

docker logs nodeapp




3.7 捕获应用日志

创建Dockerfile


FROMubuntu:18.04

LABELmaintainer="james@example.com"

ENVREFRESHED_AT 2016-06-01

RUNapt-get -qq update

RUNapt-get -qq install wget gnupg2 openjdk-8-jdk

RUNwget -qO - https://artifacts.elastic.co/GPG-KEY-elasticsearch | apt-key add -

RUNecho"deb https://artifacts.elastic.co/packages/5.x/apt stable main"| tee -a /etc/apt/sources.list.d/elastic-5.x.list

RUNapt-get -qq update

RUNapt-get -qq install logstash

WORKDIR/usr/share/logstash

ADDlogstash.conf /usr/share/logstash/

ENTRYPOINT["bin/logstash"]

CMD["-f","logstash.conf","--config.reload.automatic"]



4. 不使用SSH管理Docker容器

使用docker kill发送信号

docker kill  -s <signal> <container>

安装nsenter

工具nsenter可以进入docker用来构成容器的内核命名空间,进入一个已经存在的容器shell,即使容器没有运行ssh或任何的守护进程。

docker run -v /usr/local/bin:/target jpetazzo/nsenter

获取容器进程ID

sudo docker inspect --format '{{.State.Pid}}' nodeapp


使用nsenter进入容器

nsenter --target $PID --mount --uts --ipc --net --pid

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