docker mysql my.ini_docker官方mysql镜像自定义配置

之前为了节省安装时间,所以用官方mysql docker镜像启动mysql。

通过

$ docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d daocloud.io/mysql:tag

some-mysql 指定了该容器的名字,my-secret-pw 指定了 root 用户的密码,tag 参数指定了你想要的 MySQL 版本

这样数据是没有持久化的 所以在启动参数中需要挂载本地目录

$ docker run --name some-mysql -v /my/own/datadir:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d daocloud.io/mysql:tag

于是这样数据库一直跑着,但是由于最近程序需要支持emoji表情,不得不将mysql的字符集更改。

这时候就可以挂载自定义配置文件,官方文档说明

当 MySQL 服务启动时会以 /etc/mysql/my.cnf 为配置文件,本文件会导入 /etc/mysql/conf.d 目录中所有以 .cnf 为后缀的文件。这些文件会拓展或覆盖 /etc/mysql/my.cnf 文件中的配置。因此你可以创建你自己需要的配置文件并挂载至 MySQL 容器中的 /etc/mysql/conf.d 目录。

所以最简单改变数据库配置的方式就是在宿主机上新建配置文件,改成utf8mb4

[client]

default-character-set=utf8mb4

[mysqld]

character-set-client-handshake = FALSE

character-set-server = utf8mb4

collation-server = utf8mb4_unicode_ci

[mysql]

default-character-set=utf8mb4

随后将文件复制到相应docker容器文件夹下

docker cp /home/my.cnf(宿主机文件路径) [容器id]:/etc/mysql/mysql.conf.d

最后使用docker stop和start命令重启容器就实现了加载自定义配置。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: version: '3'services: web: image: nginx ports: - "80:80" volumes: - ./src:/usr/share/nginx/html depends_on: - db db: image: postgres environment: POSTGRES_PASSWORD: mysecretpassword volumes: - dbdata:/var/lib/postgresql/datavolumes: dbdata: ### 回答2: 编写一个docker-compose.yml文件可以用于创建和管理Docker容器。下面是一个示例: ```yaml version: '3.8' services: web: build: context: . dockerfile: Dockerfile ports: - "80:80" restart: always volumes: - ./app:/app environment: - MYSQL_HOST=db db: image: mysql:5.7 environment: - MYSQL_ROOT_PASSWORD=123456 - MYSQL_DATABASE=mydb volumes: - db_data:/var/lib/mysql volumes: db_data: ``` 上述docker-compose.yml文件包含了两个服务:web和db。web服务使用当前目录下的Dockerfile构建镜像,并将容器内的80端口映射到宿主机的80端口。此外,将当前目录下的app文件夹挂载到容器的/app路径下,使得容器内部的应用程序可以实时更新。还定义了一个名为MYSQL_HOST的环境变量,该变量的值为db,用于web服务连接到db服务。 db服务使用mysql:5.7镜像作为基础镜像,并设置了MYSQL_ROOT_PASSWORD和MYSQL_DATABASE两个环境变量。此外,将数据库数据持久化保存在名为db_data的volume中。 通过运行`docker-compose up`命令,可以创建并启动这两个服务。 ### 回答3: 编写一个docker-compose.yml文件是为了定义和管理Docker容器的部署和运行。下面是一个简单的示例,使用Nginx作为前端服务器、PHP-FPM作为后端服务器和MySQL作为数据库。 ```yaml version: '3' services: nginx: image: nginx:latest ports: - 80:80 volumes: - ./nginx.conf:/etc/nginx/conf.d/default.conf depends_on: - php php: image: php:latest volumes: - ./php.ini:/usr/local/etc/php/php.ini - ./app:/var/www/html depends_on: - db db: image: mysql:latest environment: - MYSQL_ROOT_PASSWORD=root - MYSQL_DATABASE=my_app volumes: - ./db_data:/var/lib/mysql ``` 在上面的示例中,我们定义了三个服务(nginx、php和db)。nginx服务映射主机的端口80到容器内部的端口80,并将自定义的nginx.conf文件挂载到容器的/etc/nginx/conf.d/default.conf上。 php服务使用最新的php镜像,并将自定义的php.ini文件挂载到容器的/usr/local/etc/php/php.ini上,将自定义的应用程序代码挂载到容器的/var/www/html。 db服务使用最新的mysql镜像,设置MYSQL_ROOT_PASSWORD和MYSQL_DATABASE环境变量,并将数据库数据挂载到容器的/var/lib/mysql。 通过以上定义的docker-compose.yml文件,我们可以使用docker-compose命令轻松地启动、停止和管理多个相关的容器。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值