以mysql为例:
docker run --name mysqlas #数据库命名
-p 3306:3306 #端口映射
-v /mydata/mysql/log:/var/log/mysql #文件挂载
-v /mydata/mysql/data:/var/lib/mysql
-v /mydata/mysql/conf:/etc/mysql
-e MYSQL_ROOT_PASSWORD=root #设置登录密码
-d mysql:5.7 #MySQL数据库如果不是最新版本,必须加版本号
--character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
sudo docker run --name mysql -p 3306:3306 -v /mydata/mysql/log:/var/log/mysql -v /mydata/mysql/data:/var/lib/mysql -v /mydata/mysql/conf:/etc/mysql -e MYSQL_ROOT_PASSWORD=root -d mysql:5.7
Docker容器中MySQl配置文件:
vi /mydata/mysql/conf/my.cnf
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
[mysqld]
init_connect='SET collation_connection=utf8_unicode_ci'
init_connect='SET NAMES utf8'
character-set-server=utf8
collation-server=utf8_unicode_ci
skip-character-set-client-handshake
skip-name-resolve
redis 端口映射与文件挂载
mkdir -p /mydata/redis/conf
touch /mydata/redis/conf/redis.conf
docker run --name redis
-p 6379:6379
-v /mydata/redis/data:/data
-v /mydata/redis/conf/redis.conf:/etc/redis/redis.conf
-d redis redis-server/etc/redis/redis.conf