何小豆儿在此 发表于 2024-7-27 03:53:43

云计算day05-Docker容器__kod v2,阿里面试官

6:端口映射的方式:
docker run -d -p 80:80 nginx:latest 代表,宿主机任意ip所在的80端口映射到容器80端口,默认使用tcp协议
docker run -d -p 10.0.0.13::80 nginx:latest 宿主机的10.0.0.13的随机端口映射到容器的80端口

### 2. 手动将容器保存为镜像



docker commit 容器id或者容器的名字 新的镜像名字[:版本号可选]
1):基于容器制作镜像
docker run -it centos:6.9


yum install httpd
yum install openssh-server
/etc/init.d/sshd start
vi /init.sh
#!/bin/bash
/etc/init.d/httpd start
/usr/sbin/sshd -D
chmod +x /init.sh
2)将容器提交为镜像
docker commit oldboy centos6-ssh-httpd:v1
3)测试镜像功能是否可用
手动制作的镜像,传输时间长
镜像初始命令
制作一个kodexplorer网盘docker镜像。nginx + php-fpm(httpd + php)

#### 2.1 手动制作容器步骤



>
> 手动创建一个centos6的镜像并创建一台容器
>
>
>



#创建一台基础容器,81端口映射到80端口 下载nginx
docker run -it -p 81:80 centos:6.9 /bin/bash
ifconfig
#做端口映射,在容器中下载nginx
echo “192.168.37.202 mirrors.aliyun.com” >>/etc/hosts
curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6.repo
curl -o /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo
yum install nginx -y


>
> 在宿主机上手动制作镜像
>使用创建的镜像镜像创建容器
>
>
>



#检察创建的centos6.9基础容器的ID
#创建镜像 centos6.9_nginx v1版本
#删除当前所有容器
#检察宿主机中的镜像,是否有刚刚创建的镜像
#使用新建的镜像创建容器,将82端口映射到80端口
docker ps -a
docker container commit 84265c434784 centos6.9_nginx:v1
docker container rm -f docker ps -a -q
docker image ls
docker run -d -p 82:80 centos6.9_nginx:v1 nginx -g ‘daemon off;’


>
> 访问10.0.0.11:82是否成功
>![](https://img-blog.csdnimg.cn/20190906101142710.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM3MjQyNTIw,size_16,color_FFFFFF,t_70)
>
>
>


### 3. 容器搭建\_扫雷小游戏


tomcat环境


#### 3.1 思路



1:启动centos6 基础容器
yum install tomcat
2:在容器中誊写脚本文件
vi /init.sh
#!/bin/bash
service tomcat start
tail -f /var/log/tomcat/catalina.out
3:把容器提交为镜像
docker commit 4a8871d37633 centos6.9_tomcat7:v1
4:启动容器
docker run -d -p 8081:8080 -v /opt/saolei:/var/lib/tomcat/webapps/ROOT centos6.9_tomcat7:v1 /bin/bash /init.sh

![](https://img-blog.csdnimg.cn/2019090611054315.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM3MjQyNTIw,size_16,color_FFFFFF,t_70)


#### 3.2 具体操作步骤


[扫雷软件包下载链接\_提取码: 29tu]( )



>
> 生产环境中,一般把源代码直接封装到镜像中,一运行容器就可以用,就不用 < -v > 挂载了
>
>
>



#启动centos6基础容器,下载tomcat
docker run -it -p 80:80 centos:6.9 /bin/bash
echo “192.168.37.202 mirrors.aliyun.com” >>/etc/hosts
curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6.repo
curl -o /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo
yum install tomcat -y
在容器中誊写脚本
vi /init.sh
#!/bin/bash
service tomcat start
tail -f /var/log/tomcat/catalina.out
#把容器提交为镜像
docker commit <容器ID> centos6.9_tomcat7:v1
#将扫雷代码放到/opt目次下
# ll /opt/saolei/
total 12
drwxr-xr-x 2 root root 161 Dec 3 2009 imgs
-rw-r–r-- 1 root root 9250 Dec 1 2009 saolei.jsp
#启动容器,为了夯住,背面要实验之前写的脚本文件
#假如宿主机有tomcat的环境记得修改端口映射或把宿主机的环境杀掉
pkill -9 java
docker run -d -p 8080:8080 -v /opt/saolei:/var/lib/tomcat/webapps/ROOT centos6.9_tomcat7:v1 /bin/bash /init.sh
#浏览器访问就可以玩了

![](https://img-blog.csdnimg.cn/20190906113109424.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM3MjQyNTIw,size_16,color_FFFFFF,t_70)


### 4. 容器搭建\_可道云


[可道云的站点包下载链接\_提取码: svg2]( )



#删除索引容器
docker container rm -f docker ps -a -q
================================================
#新建一个基础容器
docker run -it -p 80:80 centos6.9_nginx:v1 /bin/bash
#hosts挟制
echo “192.168.37.202 mirrors.aliyun.com” >>/etc/hosts
curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6.repo
curl -o /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo
#安装php-fpm
yum install -y php-fpm php-gd php-mbstring
#在容器中修改php设置文件
# grep ‘nginx’ /etc/php-fpm.d/www.conf
user = nginx
group = nginx
#在容器中修改nginx设置文件,设置站点目次为 /code
# cat /etc/nginx/nginx.conf
worker_processes 1;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
server {
listen 80;
server_name localhost;
location / {
root /code;
index index.php index.html index.htm;
}
location ~ .php$ {
root /code;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /code$fastcgi_script_name;
include fastcgi_params;
}
}
}
mkdir /code
#在容器中下载wget和unzip命令用来下载可道云的文件
#可道云的站点包在上面提供的下载路径可以下载使用
#解压到站点目次下后,修改站点目次的权限为nginx
yum install -y wget unzip
wget http://192.168.37.202/linux59/kodexplorer4.40.zip
mv kodexplorer4.40.zip code/
cd code/
unzip kodexplorer4.40.zip
chown -R nginx.nginx .
#启动php和nginx
service php-fpm restart
service nginx restart


>
> 浏览器访问查看![](https://img-blog.csdnimg.cn/20190906122759992.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM3MjQyNTIw,size_16,color_FFFFFF,t_70)
>
>
>



#把可道云做一个镜像
docker commit <容器ID> kod:v1
#新建一个可道云的容器
docker run -d -p 81:80 kod:v1 service php-fpm nginx start
#登录方式保证汗青命令存在
docker start <容器ID>
docker attach <容器ID>
#保证容器夯住,在容器中誊写脚本
vi /init.sh
#!/bin/bash
service php-fpm start
nginx -g ‘daemon off;’
#将php-fpm和nginx关闭掉
service php-fpm stop
service nginx stop
#测试脚本是否可用
sh /init.sh
#再次做镜像v2
docker commit <容器ID> kod:v2
#使用镜像v2运行一个新的容器
docker run -d -p 81:80 kod:v2 /bin/bash /init.sh


>
> ![](https://img-blog.csdnimg.cn/20190906124552446.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM3MjQyNTIw,size_16,color_FFFFFF,t_70)
>完成
>
>
>


### 5. 容器搭建\_phpwind论坛


( )



#新建一个基础容器,80端口映射,80端口,
#与上一个项目的可道云的81端口不要冲突
docker run -it -p 80:80 centos6.9_nginx:v1 /bin/bash
#在容器中实验,hosts本地挟制
echo “192.168.37.202 mirrors.aliyun.com” >>/etc/hosts
curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6.repo
curl -o /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo
#下载php环境和必要用的的命令
yum install -y wget unzip php-fpm php-gd php-mbstring php-mysql vim
#拉取phpwind论坛的站点包,上面已有下载链接
wget http://192.168.37.202/linux59/phpwind_UTF8_8.7.1.zip
#创建站点目次,解压后并修改权限为nginx
mkdir /code
mv phpwind_UTF8_8.7.1.zip code/
cd /code
unzip phpwind_UTF8_8.7.1.zip
chown -R nginx.nginx .
#修改php-fpm设置文件
# grep ‘nginx’ /etc/php-fpm.d/www.conf
user = nginx
group = nginx
#在容器中修改nginx设置文件,设置站点目次为 /code/upload
# cat /etc/nginx/nginx.conf
worker_processes 1;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
server {
listen 80;
server_name localhost;
location / {
root /code/upload;
index index.php index.html index.htm;
}
location ~ .php$ {
root /code/upload;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /code/upload$fastcgi_script_name;
include fastcgi_params;
}
}
}
#启动php-fpm和nginx服务
service php-fpm restart
service nginx restart
#安装数据库并启动
yum install -y mysql-libs mysql-server
service mysqld restart
#进入数据库创库,删除空表
#为数据库创建密码
# mysqladmin -uroot -p password 123456
# mysql -uroot -p123456
#删除空表
mysql> select user,host from mysql.user;
mysql> drop user ‘’@‘2fc2234b814b’;
mysql> drop user ‘’@‘localhost’;
mysql> flush privileges;
#创建phpwind库
mysql> create database phpwind charset utf8;
mysql> show databases;
#调解时区
# /bin/cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
# date
Fri Sep 6 15:26:33 CST 2019
#重启服务
service php-fpm restart
service nginx restart
service mysqld restart


>
> 浏览器访问查看![](https://img-blog.csdnimg.cn/20190906135108242.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM3MjQyNTIw,size_16,color_FFFFFF,t_70)![](https://img-blog.csdnimg.cn/20190906142503344.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM3MjQyNTIw,size_16,color_FFFFFF,t_70)![](https://img-blog.csdnimg.cn/20190906142414101.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM3MjQyNTIw,size_16,color_FFFFFF,t_70)![](https://img-blog.csdnimg.cn/20190906143110426.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM3MjQyNTIw,size_16,color_FFFFFF,t_70)
>![](https://img-blog.csdnimg.cn/20190906153735250.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM3MjQyNTIw,size_16,color_FFFFFF,t_70)![](https://img-blog.csdnimg.cn/20190906153759546.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM3MjQyNTIw,size_16,color_FFFFFF,t_70)
>
>
>




---


### 6. dockerfile自动构建docker镜像



![](https://img-blog.csdnimg.cn/20190906155922153.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM3MjQyNTIw,size_16,color_FFFFFF,t_70)
类似ansible剧本,大小几kb
手动做镜像:大小几百M+


dockerfile 支持自定义容器的初始命令


dockerfile主要组成部分:
​ 基础镜像信息 FROM centos:6.9
​ 制作镜像操作指令 RUN yum install openssh-server -y
​ 容器启动时执行初始命令 CMD ["/bin/bash"]
dockerfile常用指令:



FROM 这个镜像的妈妈是谁?(指定基础镜像)
MAINTAINER 告诉别人,谁负责养它?(指定维护者信息,可以没有)
LABLE 描述,标签
RUN 你想让它干啥(在命令前面加上RUN即可)
ADD 给它点创业资金(会自动解压tar) 制作docker基础的体系镜像
WORKDIR 我是cd,今天刚化了妆(设置当前工作目次)
VOLUME 给它一个存放行李的地方(设置卷,挂载主机目次)
EXPOSE 它要打开的门是啥(指定对外的端口)(-P 随机端口)
CMD 奔跑吧,兄弟!(指定容器启动后的要干的事情)(容易被替换)
dockerfile其他指令:
COPY 复制文件(不会解压)rootfs.tar.gz
ENV 环境变量
ENTRYPOINT 容器启动后实验的命令(无法被替换,启容器的时候指定的命令,会被当成参数)

#### 6.1 测试——FROM & RUN



#手动制作一次docker镜像(网络命令)
#编写dockerfile文件
# mkdir -p /opt/dockerfile/nginx
# cd /opt/dockerfile/nginx
# vim dockerfile
FROM centos:6.9
RUN curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6.repo
RUN curl -o /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo
RUN yum install nginx -y
CMD [“nginx”,“-g”,“daemon off;”]
#docker build自动构建docker镜像
# docker image build -t centos6.9_nginx:v2 --network=host /opt/dockerfile/nginx

Successfully built 05342d047d21
Successfully tagged centos6.9_nginx:v2
#测试镜像可不可以使用
docker run -d -p 88:80 centos6.9_nginx:v2

![](https://img-blog.csdnimg.cn/2019090616184462.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM3MjQyNTIw,size_16,color_FFFFFF,t_70)



自我先容一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数大数据工程师,想要提升技能,每每是自己探索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术故步自封!
因此网络整理了一份《2024年大数据全套学习资料》,初衷也很简朴,就是盼望可以或许帮助到想自学提升又不知道该从何学起的朋侪。
https://img-blog.csdnimg.cn/img_convert/64e6e4a55a60b6a11d9902c36e42f18e.png
https://img-blog.csdnimg.cn/img_convert/946ab8387ce283f0b3ebfe9f42b613f1.png
https://img-blog.csdnimg.cn/img_convert/692cb4de9dd3e79b697fe0787630a554.png
https://img-blog.csdnimg.cn/img_convert/927a6f0ddd1b4a9247c9acec0b42f6e4.png
https://img-blog.csdnimg.cn/img_convert/07c18655e819a274e347078f45ade105.png
既有得当小白学习的零基础资料,也有得当3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上大数据开发知识点,真正体系化!
由于文件比力大,这里只是将部门目次大纲截图出来,每个节点里面都包含大厂面经、学习条记、源码讲义、实战项目、解说视频,而且后续会持续更新
假如你以为这些内容对你有帮助,可以添加VX:vip204888 (备注大数据获取)
https://img-blog.csdnimg.cn/img_convert/a3b12b19927fd978f8c723524edf007d.png
一个人可以走的很快,但一群人才气走的更远。岂论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
0469)]
[外链图片转存中…(img-gGaFQMSj-1713105460469)]
[外链图片转存中…(img-18iY1FXW-1713105460470)]
[外链图片转存中…(img-mkfPK2lA-1713105460470)]
[外链图片转存中…(img-tsmmwf9t-1713105460470)]
既有得当小白学习的零基础资料,也有得当3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上大数据开发知识点,真正体系化!
由于文件比力大,这里只是将部门目次大纲截图出来,每个节点里面都包含大厂面经、学习条记、源码讲义、实战项目、解说视频,而且后续会持续更新
假如你以为这些内容对你有帮助,可以添加VX:vip204888 (备注大数据获取)
[外链图片转存中…(img-V3r1UmZK-1713105460470)]
一个人可以走的很快,但一群人才气走的更远。岂论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 云计算day05-Docker容器__kod v2,阿里面试官