demo1 :docker 打包 spring boot 镜像
Dockerfile
# 基础镜像使用Java
FROM java:8
# 作者
MAINTAINER Yonglong Xue
# 将jar包添加到容器中并更名为app.jar
ADD certificate-manager-0.0.1-SNAPSHOT.jar app.jar
# 运行jar包
RUN bash -c 'touch /app.jar'
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]
# 指定容器需要映射到主机的端口
EXPOSE 8080
编译、运行
docker image build cert:版本号(不写为最新版) . (.号不能少)
docker run --network=app --name cert -d -p 8080:8080 cert
demo2 :docker 打包 mysql 镜像
Dockerfile
# 指定基础镜像,选用docker官方最新mysql镜像
FROM mysql:5.7
# 环境变量设置,设置mysql登陆时不需密码
# ENV MYSQL_ALLOW_EMPTY_PASSWORD yes
# 复制文件到容器中,要复制的文件有:启动脚本和sql文件
COPY install_data.sh /docker-entrypoint-initdb.d/install_data.sh
COPY data.sql /mysql/data.sql
install_data.sh
#!/bin/bash
mysql -uroot -p$MYSQL_ROOT_PASSWORD <<EOF
source /mysql/data.sql
data.sql
-- 创建数据库
DROP database IF EXISTS `docker_database`;
create database `docker_database` default character set utf8 collate utf8_general_ci;
-- 切换到test_data数据库
use docker_database;
-- 建表
DROP TABLE IF EXISTS `person`;
CREATE TABLE `person` (
`id` bigint(20) NOT NULL,
`name` varchar(255) DEFAULT NULL,
`age` bigint(20) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
-- 插入数据
INSERT INTO `user` (`id`,`name`,`age` )
VALUES
(0,'Tom',18);
编译、运行
docker image build -t cert_mysql:5.7 .
docker run --network=app --name mysql -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=mariadb cert_mysql:5.7
随笔记录
docker 导出、导入镜像
docker save cert_mysql:5.7 > cert_mysql_5.7.tar
docker load < cert_mysql_5.7.tar
docker 创建 network
docker network create app
docker 容器连接 network
docker network connect app cert
相关链接
docker-制作自定义mysql镜像
Docker 网络-端口映射、容器链接、Networking