Docker 实战——部署 Nginx 镜像容器、Tomcat 镜像容器、MySQL 镜像容器

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: Docker 实战——部署 Nginx 镜像容器、Tomcat 镜像容器、MySQL 镜像容器

Docker 实战——部署 Nginx 镜像容器、Tomcat 镜像容器、MySQL 镜像容器



一、安装 Docker


1.安装需要的软件包

2.设置 Docker 的 yum 源

3.安装 Docker

4.启动 Docker 并设置开机自启

5.验证 Docker 是否安装成功

6.配置 Docker 加速器


二、部署 Nginx 镜像容器


1.下载基础镜像

2.创建工作目录

3.编写 Dockerfile 文件

4.编写执行脚本内容

5.生成镜像

6.启动容器并验证


三、部署 Tomcat 镜像容器


1.创建工作目录,并拖入相关软件

2.编写 Dockerfile 文件

3.编写执行脚本内容

4.生成镜像

5.运行容器并验证


四、部署 MySQL 镜像容器


1.创建工作目录,并拖入相关软件

2.编写 Dockerfile 文件

3.创建其他相关文件

4.生成镜像

5.运行容器并验证

1)进入容器,登录数据库

2)在宿主机上安装 mariadb 来进行验证


一、安装 Docker



准备工作:


image.png



  • 注意:使用的机器需能够上网。


1.安装需要的软件包


[root@Docker ~]# yum -y install yum-utils device-mapper-persistent-data lvm2


2.设置 Docker 的 yum 源


[root@Docker ~]# wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
[root@Docker ~]# yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo


image.png


3.安装 Docker


可使用 yum list docker-ce --showduplicates | sort -r 命令来查看 Docker 的所有版本。


[root@Docker ~]# yum -y install docker-ce-17.12.1.ce      #安装docker


4.启动 Docker 并设置开机自启


[root@Docker ~]# systemctl start docker
[root@Docker ~]# systemctl enable docker


5.验证 Docker 是否安装成功


[root@Docker ~]# docker version           #查看Docker版本


image.png


6.配置 Docker 加速器


[root@Docker ~]# cat <<END > /etc/docker/daemon.json
{
    "registry-mirrors": [
        "https://1nj0zren.mirror.aliyuncs.com",
        "https://docker.mirrors.ustc.edu.cn",
        "http://f1361db2.m.daocloud.io",
        "https://registry.docker-cn.com"
    ]
}
END
[root@Docker ~]# systemctl daemon-reload      #重新加载systemd配置
[root@Docker ~]# systemctl restart docker       #重启docker


image.png


二、部署 Nginx 镜像容器



1.下载基础镜像


[root@Docker ~]# docker pull dadoha/centos7.4.1708
[root@Docker ~]# docker images


image.png


2.创建工作目录


[root@Docker ~]# mkdir nginx
[root@Docker ~]# cd nginx/


image.png


3.编写 Dockerfile 文件


[root@Docker nginx]# vim Dockerfile
#设置基础镜像
FROM dadoha/centos7.4.1708
#维护该镜像的用户信息
MAINTAINER zhangsan
#安装相关依赖包
RUN yum clean all ; yum -y install proc-devel net-tools gcc zlib zlib-devel make openssl-devel wget
#下载并解压nginx软件包
RUN wget http://nginx.org/download/nginx-1.12.0.tar.gz
RUN tar zxf nginx-1.12.0.tar.gz -C /usr/src/
#切换目录
WORKDIR /usr/src/nginx-1.12.0/
#编译安装
RUN ./configure --prefix=/usr/local/nginx && make && make install
#开启端口
EXPOSE 80
EXPOSE 443
#修改nginx文件,以非daemon方式启动
RUN echo "daemon off;" >> /usr/local/nginx/conf/nginx.conf
#复制启动脚本
ADD run.sh /
RUN chmod 755 /run.sh
#运行启动脚本
CMD ["/run.sh"]


4.编写执行脚本内容


[root@Docker nginx]# cat <<END > run.sh
#!/bin/bash
/usr/local/nginx/sbin/nginx
END


image.png


5.生成镜像


[root@Docker nginx]# docker build -t nginx:v1.2 .


6.启动容器并验证


[root@Docker nginx]# docker images
[root@Docker nginx]# docker run -d --name nginx -p 888:80 nginx:v1.2
[root@Docker nginx]# docker ps


image.png


验证:使用浏览器访问 http://192.168.1.1:888


image.png


三、部署 Tomcat 镜像容器




1.创建工作目录,并拖入相关软件


[root@Docker ~]# mkdir tomcat
[root@Docker ~]# cd tomcat/
[root@Docker tomcat]# ls
apache-tomcat-8.5.16.tar.gz  jdk-8u91-linux-x64.tar.gz
[root@Docker tomcat]# tar zxf jdk-8u91-linux-x64.tar.gz 
[root@Docker tomcat]# ls
apache-tomcat-8.5.16.tar.gz  jdk1.8.0_91  jdk-8u91-linux-x64.tar.gz


image.png


2.编写 Dockerfile 文件


[root@docker tomcat]# vim Dockerfile
#设置基础镜像
FROM dadoha/centos7.4.1708
#维护该镜像的用户信息
MAINTAINER zhangsan
#给JDK设置变量
ADD jdk1.8.0_91 /usr/local/java
ENV JAVA_HOME /usr/local/java
ENV JAVA_BIN /usr/local/java/bin
ENV JRE_HOME /usr/local/java/jre
ENV PATH $PATH:/usr/local/java/bin/:/usr/local/java/jre/bin
ENV CLASSPATH /usr/local/java/jre/bin:/usr/local/java/lib:/usr/local/java/jre/lib/charsets.jar
#传入tomcat软件包
COPY apache-tomcat-8.5.16.tar.gz /
RUN tar zxf /apache-tomcat-8.5.16.tar.gz
#将解压后文件移动位置,重命名为tomcat
RUN mv /apache-tomcat-8.5.16 /usr/local/tomcat
#开启8080端口
EXPOSE 8080
#复制启动脚本
ADD run.sh /
RUN chmod 755 /run.sh
#运行启动脚本
CMD ["/run.sh"]


3.编写执行脚本内容


[root@Docker tomcat]# cat <<END > run.sh 
#!/bin/bash
/usr/local/tomcat/bin/startup.sh
tailf /run
END


image.png


4.生成镜像


[root@Docker tomcat]# docker build -t tomcat:v8.5 .


5.运行容器并验证


[root@Docker tomcat]# docker images | grep tomcat
[root@Docker tomcat]# docker run -d --name tomcat -p 8888:8080 tomcat:v8.5
[root@Docker tomcat]# docker ps | grep tomcat


image.png


验证:使用浏览器访问 http://192.168.1.1:8888


image.png


四、部署 MySQL 镜像容器




1.创建工作目录,并拖入相关软件


[root@Docker ~]# mkdir mysql
[root@Docker ~]# cd mysql/
[root@Docker mysql]# ls
boost_1_59_0.tar.bz2  mysql-5.7.12.tar.gz


image.png


2.编写 Dockerfile 文件


[root@Docker mysql]# vim Dockerfile
#设置基础镜像
FROM dadoha/centos7.4.1708
#维护该镜像的用户信息
MAINTAINER zhangsan
#下载相关工具
RUN yum -y groupinstall "开发工具"
RUN yum -y install zlib zlib-devel gcc gcc-c++ ncurses ncurses-devel bison libgcrypt perl cmake net-tools
#创建mysql用户和组
RUN groupadd mysql
RUN useradd -r -g mysql mysql
#复制软件包到指定目录(将会自动解压)
ADD boost_1_59_0.tar.bz2 /usr/local/
ADD mysql-5.7.12.tar.gz /tmp/
#指定工作目录
WORKDIR /tmp/mysql-5.7.12/
#cmake配置及编译安装
RUN cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DMYSQL_TCP_PORT=3306 -DMYSQL_USER=mysql \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_MEMORY_STORAGE_ENGINE=1 \
-DENABLE_DOWNLOADS=1 \
-DDOWNLOAD_BOOST=1 \
-DWITH_BOOST=/usr/local/boost_1_59_0 \
-DSYSCONFDIR=/etc && make && make install
#更改mysql目录的属主和属组
RUN chown -R mysql:mysql /usr/local/mysql
#删除默认安装的my.cnf文件
RUN rm -rf /etc/my.cnf
#复制一份my.cnf到/etc/目录
ADD my.cnf /etc/
#复制启动脚本
RUN cp /tmp/mysql-5.7.12/support-files/mysql.server /etc/init.d/
RUN chmod +x /etc/init.d/mysql.server
ADD mysqld.service /usr/lib/systemd/system/
#设置环境变量
ENV PATH $PATH:/usr/local/mysql/bin/
#创建日志目录
RUN mkdir /usr/local/mysql/logs
RUN chown mysql:mysql /usr/local/mysql/logs/
#开启3306端口
EXPOSE 3306
#初始化设置
RUN mysqld --initialize-insecure --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
#直接设置运行启动脚本
RUN echo -e "#!/bin/bash \nsystemctl enable mysqld" > /run.sh
#给予权限
RUN chmod 755 /run.sh
RUN sh /run.sh
#启动容器时执行
CMD ["init"]


3.创建其他相关文件


[root@Docker mysql]# vim my.cnf
[mysqld]
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
port = 3306
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
character_set_server=utf8
init_connect='SET NAMES utf8'
log-error=/usr/local/mysql/logs/mysqld.log
pid-file=/usr/local/mysql/logs/mysqld.pid
skip-name-resolve


[root@Docker mysql]# vim mysqld.service
[Unit]
Description=mysqldapi
After=network.target
[Service]
Type=forking
PIDFile=/usr/local/mysql/logs/mysqld.pid
ExecStart=/etc/init.d/mysql.server start
ExecReload=/etc/init.d/mysql.server restart
ExecStop=/etc/init.d/mysql.server stop
PrivateTmp=Flase
[Install]
WantedBy=multi-user.target


image.png


4.生成镜像


[root@Docker mysql]# docker build -t mysql:v5.7 .


5.运行容器并验证


  • --privileged:表示不降权,也就是进入容器中,也可以是 root 权限。


[root@Docker mysql]# docker images | grep mysql
[root@Docker mysql]# docker run -d --name mysql -p 13306:3306 --privileged mysql:v5.7
[root@Docker mysql]# docker ps | grep mysql


image.png


1)进入容器,登录数据库


  • 如果进入容器后使用 netstat -anpt | grep 3306 查不到端口,则通过 /etc/init.d/mysql.server start 来启动。


[root@Docker mysql]# docker exec -it mysql /bin/bash
[root@75f6e0308671 mysql-5.7.12]# netstat -anpt | grep 3306
mysql> grant all privileges on *.* to 'root'@'%' identified by '123456';
mysql> flush privileges;


image.png


2)在宿主机上安装 mariadb 来进行验证


[root@Docker ~]# yum -y install mariadb
[root@Docker ~]# mysql -uroot -p123456 -h192.168.1.1 -P13306


image.png


  • 注意:如果出现如下错误是因为远程的数据库未启动。


image.png


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
26天前
|
SQL 关系型数据库 MySQL
【MySQL技术专题】「问题实战系列」深入探索和分析MySQL数据库的数据备份和恢复实战开发指南(8.0版本升级篇)
【MySQL技术专题】「问题实战系列」深入探索和分析MySQL数据库的数据备份和恢复实战开发指南(8.0版本升级篇)
96 0
|
2天前
|
关系型数据库 MySQL 中间件
【MySQL实战笔记】07 | 行锁功过:怎么减少行锁对性能的影响?-02 死锁和死锁检测
【4月更文挑战第19天】在高并发环境下,死锁发生在多个线程间循环等待资源时,导致无限期等待。MySQL中,死锁可通过`innodb_lock_wait_timeout`参数设置超时或`innodb_deadlock_detect`开启死锁检测来解决。默认的50s超时可能不适用于在线服务,而频繁检测会消耗大量CPU。应对热点行更新引发的性能问题,可以暂时关闭死锁检测(风险是产生大量超时),控制并发度,或通过分散记录减少锁冲突,例如将数据分拆到多行以降低死锁概率。
18 1
|
5天前
|
SQL 关系型数据库 MySQL
Python与MySQL数据库交互:面试实战
【4月更文挑战第16天】本文介绍了Python与MySQL交互的面试重点,包括使用`mysql-connector-python`或`pymysql`连接数据库、执行SQL查询、异常处理、防止SQL注入、事务管理和ORM框架。易错点包括忘记关闭连接、忽视异常处理、硬编码SQL、忽略事务及过度依赖低效查询。通过理解这些问题和提供策略,可提升面试表现。
25 6
|
12天前
|
存储 关系型数据库 MySQL
【MySQL实战笔记】 04 | 深入浅出索引(上)-02
【4月更文挑战第9天】InnoDB数据库使用B+树作为索引模型,其中主键索引的叶子节点存储完整行数据,非主键索引则存储主键值。主键查询只需搜索一棵树,而非主键查询需两次搜索,因此推荐使用主键查询以提高效率。在插入新值时,B+树需要维护有序性,可能导致数据页分裂影响性能。自增主键在插入时可避免数据挪动和页分裂,且占用存储空间小,通常更为理想。然而,如果场景仅需唯一索引,可直接设为主键以减少查询步骤。
13 1
【MySQL实战笔记】 04 | 深入浅出索引(上)-02
|
14天前
|
存储 SQL 关系型数据库
【MySQL实战笔记】03.事务隔离:为什么你改了我还看不见?-02
【4月更文挑战第7天】数据库通过视图实现事务隔离,不同隔离级别如读未提交、读已提交、可重复读和串行化采用不同策略。以可重复读为例,MySQL使用多版本并发控制(MVCC),每个事务有其独立的视图。回滚日志在无更早视图时被删除。长事务可能导致大量存储占用,应避免。事务启动可显式用`begin`或设置`autocommit=0`,但后者可能意外开启长事务。建议使用`autocommit=1`并显式管理事务,若需减少交互,可使用`commit work and chain`。
29 5
|
15天前
|
Linux Shell 虚拟化
linux 部署docker容器虚拟化平台(二)--------docker 镜像制作方法
linux 部署docker容器虚拟化平台(二)--------docker 镜像制作方法
26 0
|
16天前
|
SQL 存储 关系型数据库
【MySQL实战笔记】02.一条SQL更新语句是如何执行的-2
【4月更文挑战第5天】两阶段提交是为确保`redo log`和`binlog`逻辑一致,避免数据不一致。若先写`redo log`, crash后数据可能丢失,导致恢复后状态错误;若先写`binlog`,crash则可能导致重复事务,影响数据库一致性。一天一备相较于一周一备,能缩短“最长恢复时间”,但需权衡额外的存储成本。
16 1
|
26天前
|
SQL 关系型数据库 MySQL
【MySQL技术专题】「问题实战系列」深入探索和分析MySQL数据库的数据备份和恢复实战开发指南(数据恢复补充篇)(一)
【MySQL技术专题】「问题实战系列」深入探索和分析MySQL数据库的数据备份和恢复实战开发指南(数据恢复补充篇)
30 0
|
27天前
|
NoSQL 关系型数据库 MySQL
安装Docker&镜像容器操作&使用Docker安装部署MySQL,Redis,RabbitMQ,Nacos,Seata,Minio
安装Docker&镜像容器操作&使用Docker安装部署MySQL,Redis,RabbitMQ,Nacos,Seata,Minio
225 1
|
1月前
|
存储 Kubernetes 关系型数据库
KubeSphere 核心实战之一【在kubesphere平台上部署mysql】(实操篇 1/4)
KubeSphere 核心实战之一【在kubesphere平台上部署mysql】(实操篇 1/4)
46 0