云计算day05-Docker容器__kod v2

134 阅读9分钟

文章目录

1. docker知识点回顾

1:什么是容器?

容器在隔离环境中运行的一个进程,隔离的环境,有自己的系统文件,ip地址,主机名,进程管理


alpine  linux    iso 300M


2:容器想对于虚拟化,它的优势?

轻量级,启动快,性能高,损耗少


3:docker是一种容器技术(namespace  资源隔离,cgroup  资源限制)

docker软件的打包技术


4:镜像常用命令:

docker search:    在线搜索镜像,  官方的,start数多的

docker  pull    拉取镜像,下载镜像   == docker   image  pull

docker  push  推送镜像,上传镜像   == docker  image   push

docker  images == docker  image  ls   查看镜像列表

docker  image  rm   删除镜像   == docker   rmi

docker  image  load    导入镜像  == docker  load,   docker  import导入镜像

docker_nginx.tar.gz   怎么导入?

docker  load  -i     docker_nginx.tar.gz 

docker  image   save   导出镜像 == docker  save

nginx  1.15怎么导出镜像

docker  save  -o   docker_nginx.tar.gz   nginx:1.15

docker  image  tag   给镜像打标签



5:容器常用操作:

docker   run   ==   docker  container   run

docker  run    -it   -v   -p   -d  -P  --name  

-it  分配一个交互式的终端

-v   把宿主机目录或者卷挂载到容器中

-p  端口映射

-P  自动随机端口映射

-d  后台运行

容器的第一个进程必须夯住,   容器中运行业务:  即把业务服务启动,还要容器夯住(知识量的积累)  nginx  -g  'daemon off;'



docker  start   == docker  container  start

docker  stop  ==  docker  container  stop

docker  restart  == docker  container  restart

docker  kill   == docker  container  kill

docker   ps  ==  docker  container  ls  == docker  container  ps

docker   rm ==  docker  container  rm

docker   attach  == docker  container  attach

docker  exec   == docker  container  exec

docker  cp   ==  docker  container  cp

docker   inspect   

docekr  logs


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是否成功

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

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目录下
[root@docker01 ~]# 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

#浏览器访问就可以玩了

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配置文件
[root@de6c450c9fe9 /]# grep 'nginx' /etc/php-fpm.d/www.conf
user = nginx
group = nginx

#在容器中修改nginx配置文件,设置站点目录为 /code
[root@de6c450c9fe9 /]# 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

浏览器访问查看

#把可道云做一个镜像
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



完成

5. 容器搭建_phpwind论坛

phpwind论坛站点包下载链接_提取码: fw6p

#新建一个基础容器,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配置文件
[root@2fc2234b814b code]# grep 'nginx' /etc/php-fpm.d/www.conf
user = nginx
group = nginx

#在容器中修改nginx配置文件,设置站点目录为 /code/upload
[root@de6c450c9fe9 /]# 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


为了做好运维面试路上的助攻手,特整理了上百道 **【运维技术栈面试题集锦】** ,让你面试不慌心不跳,高薪offer怀里抱!

这次整理的面试题,**小到shell、MySQL,大到K8s等云原生技术栈,不仅适合运维新人入行面试需要,还适用于想提升进阶跳槽加薪的运维朋友。**

![](https://p3-xtjj-sign.byteimg.com/tos-cn-i-73owjymdk6/75e94bd8484d4f39852b15b238f8b535~tplv-73owjymdk6-jj-mark-v1:0:0:0:0:5o6Y6YeR5oqA5pyv56S-5Yy6IEAg55So5oi3MDgwNDUxMTkwMTI=:q75.awebp?rk3s=f64ab15b&x-expires=1771511634&x-signature=FjYK91D%2FZwSMfQZQS8p7Hn9bFqE%3D)

本份面试集锦涵盖了

*   **174 道运维工程师面试题**
*   **128道k8s面试题**
*   **108道shell脚本面试题**
*   **200道Linux面试题**
*   **51道docker面试题**
*   **35道Jenkis面试题**
*   **78道MongoDB面试题**
*   **17道ansible面试题**
*   **60道dubbo面试题**
*   **53道kafka面试**
*   **18道mysql面试题**
*   **40道nginx面试题**
*   **77道redis面试题**
*   **28道zookeeper**

**总计 1000+ 道面试题, 内容 又全含金量又高**

*   **174道运维工程师面试题**

> 1、什么是运维?

> 2、在工作中,运维人员经常需要跟运营人员打交道,请问运营人员是做什么工作的?

> 3、现在给你三百台服务器,你怎么对他们进行管理?

> 4、简述raid0 raid1raid5二种工作模式的工作原理及特点

> 5、LVS、Nginx、HAproxy有什么区别?工作中你怎么选择?

> 6、Squid、Varinsh和Nginx有什么区别,工作中你怎么选择?

> 7、Tomcat和Resin有什么区别,工作中你怎么选择?

> 8、什么是中间件?什么是jdk?

> 9、讲述一下Tomcat8005、8009、8080三个端口的含义?

> 10、什么叫CDN?

> 11、什么叫网站灰度发布?

> 12、简述DNS进行域名解析的过程?

> 13、RabbitMQ是什么东西?

> 14、讲一下Keepalived的工作原理?

> 15、讲述一下LVS三种模式的工作过程?

> 16、mysql的innodb如何定位锁问题,mysql如何减少主从复制延迟?

> 17、如何重置mysql root密码?
详情docs.qq.com/doc/DSmdCdUNwcEJDTXFK