1.安装mysql5.7
1.拉取镜像
docker pull mysql:5.7
2.创建镜像挂载文件夹
创建命令:mkdir mydata (在根目录下创建)
3.docker启动mysql
启动命令
docker run -p 3306:3306 --name mysql \ 将容器的3306端口映射到主机的3306端口
-v /mydata/mysql/log:/var/log/mysql \
-v /mydata/mysql/data:/var/lib/mysql \
-v /mydata/mysql/conf:/etc/mysql \ 将配置、日志等文件挂载到主机
-e TZ=Asia/Shanghai \ 配置时区
-e MYSQL_ROOT_PASSWORD=root \ 初始化root账号密码为root
-d mysql:5.7
启动完成后查看镜像服务是否启动成功:docker ps
4.配置mysql
进入挂载mysql配置文件的目录:cd /mydata/mysql/conf/
修改my.cnf文件:vim 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
docker重启mysql使配置生效:docker restart mysql
设置mysql在docker自启:docker update mysql --restart=always
使用navicat连接数据库进行测试
2.安装redis
1.安装redis镜像
docker pull redis (拉取镜像)
docker images (查看镜像是否安装成功)
2.创建redis挂载目录
mkdir -p /mydata/redis/conf
3.创建redis配置文件
touch /mydata/redis/conf/redis.conf
4.启动redis镜像
docker run -p 6379:6379 --name redis \
-v /mydata/redis/data:/data \
-v /mydata/redis/conf/redis.conf:/etc/redis/redis.conf \
-d redis redis-server /etc/redis/redis.conf
5.查看镜像是否启动成功
docker ps
6.配置redis持久化
echo "appendonly yes" >> /mydata/redis/conf/redis.conf
docker restart redis (重启redis,配置生效)
7.设置redis自启
docker update redis --restart=always
8.redis安装完成
使用RESP进行连接测试
3.安装nginx
1.拉取镜像
docker pull nginx
docker images (查看镜像列表)
2.创建nginx挂载目录
mkdir -p /mydata/nginx
mkdir -p /mydata/nginx/conf
mkdir -p /mydata/nginx/logs
mkdir -p /mydata/nginx/www
3.创建nginx配置文件
touch nginx.conf (在conf目录下创建)
拷贝以下内容
user nginx; #设置nginx服务的系统使用用户
worker_processes 1; #工作进程数
error_log /var/log/nginx/error.log warn; #nginx的错误日志
pid /var/run/nginx.pid; #nginx启动时候的pid
events {
worker_connections 1024; #每个进程允许的最大连接数
}
http { #http请求配置,一个http可以包含多个server
#定义 Content-Type
include /etc/nginx/mime.types;
default_type application/octet-stream;
#日志格式 此处main与access_log中的main对应
#$remote_addr:客户端地址
#$remote_user:http客户端请求nginx认证的用户名,默认不开启认证模块,不会记录
#$timelocal:nginx的时间
#$request:请求method + 路由 + http协议版本
#status:http reponse 状态码
#body_bytes_sent:response body的大小
#$http_referer:referer头信息参数,表示上级页面
#$http_user_agent:user-agent头信息参数,客户端信息
#$http_x_forwarded_for:x-forwarded-for头信息参数
log_format main '$http_user_agent' '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
#访问日志,后面的main表示使用log_format中的main格式记录到access.log中
access_log /var/log/nginx/access.log main;
#nginx的一大优势,高效率文件传输
sendfile on;
#tcp_nopush on;
#客户端与服务端的超时时间,单位秒
keepalive_timeout 65;
#gzip on;
server { #http服务,一个server可以配置多个location
listen 80; #服务监听端口
server_name localhost; #主机名、域名
#charset koi8-r;
#access_log /var/log/nginx/host.access.log main;
location / {
root /usr/share/nginx/html; #页面存放目录
index index.html index.htm; #默认页面
}
#error_page 404 /404.html;
# 将500 502 503 504的错误页面重定向到 /50x.html
error_page 500 502 503 504 /50x.html;
location = /50x.html { #匹配error_page指定的页面路径
root /usr/share/nginx/html; #页面存放的目录
}
# proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
#location ~ \.php$ {
# proxy_pass http://127.0.0.1;
#}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
#location ~ \.php$ {
# root html;
# fastcgi_pass 127.0.0.1:9000;
# fastcgi_index index.php;
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
# include fastcgi_params;
#}
# deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
#location ~ /\.ht {
# deny all;
#}
}
include /etc/nginx/conf.d/*.conf;
}
4.启动nginx镜像
docker run -p 80:80 --name=nginx \
-v /mydata/nginx/www:/usr/share/nginx/html \
-v /mydata/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /mydata/nginx/logs:/var/log/nginx \
-d nginx
5.测试nginx
在www目录下创建index.html文件
vim /mydata/nginx/www/index.html
<html>
<h1>hello world</h1>
</html>
6.设置nginx自启
docker update redis --restart=always