window环境docker配置nginx+php+mysql 网站运行环境

安装nginx容器
docker run -p 80:80 -d --name nginx -v D:\docker\nginx\default.conf:/etc/nginx/conf.d/default.conf -v D:\docker\www:/docker/www  --privileged=true nginx

D:\docker\nginx\ 为window 目录路径 /docker/www 为容器内映射路径

安装PHP容器
docker run -p 9000:9000 -d --name php -v D:\docker\www:/docker/www --privileged=true php:7.4-fpm

查看容器IP地址

docker inspect php | grep "IPAddress"
安装mysql
  • MySql配置文件内容 my.cnf
[root@localhost docker]# vim /etc/my.cnf

[client]
port		= 3306
socket		= /tmp/mysql.sock

[mysqld]
secure_file_priv=/var/lib/mysql
port		= 3306
socket		= /tmp/mysql.sock
datadir = /usr/local/mysql/data
default_storage_engine = InnoDB
performance_schema_max_table_instances = 400
table_definition_cache = 400
skip-external-locking
key_buffer_size = 32M
max_allowed_packet = 100G
table_open_cache = 128
sort_buffer_size = 768K
net_buffer_length = 4K
read_buffer_size = 768K
read_rnd_buffer_size = 256K
myisam_sort_buffer_size = 8M
thread_cache_size = 16
tmp_table_size = 32M
default_authentication_plugin = mysql_native_password
lower_case_table_names = 1
sql-mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

explicit_defaults_for_timestamp = true
max_connections = 500
max_connect_errors = 100
open_files_limit = 65535

log-bin=mysql-bin
binlog_format=mixed
server-id = 1
binlog_expire_logs_seconds = 600000
slow_query_log=1
slow-query-log-file=/usr/local/mysql/data/mysql-slow.log
long_query_time=3
early-plugin-load = ""

innodb_data_home_dir = /usr/local/mysql/data
innodb_data_file_path = ibdata1:10M:autoextend
innodb_log_group_home_dir = /usr/local/mysql/data
innodb_buffer_pool_size = 128M
innodb_log_file_size = 64M
innodb_log_buffer_size = 16M
innodb_flush_log_at_trx_commit = 1
innodb_lock_wait_timeout = 50
innodb_max_dirty_pages_pct = 90
innodb_read_io_threads = 1
innodb_write_io_threads = 1

[mysqldump]
quick
max_allowed_packet = 500M

[mysql]
no-auto-rehash

[myisamchk]
key_buffer_size = 32M
sort_buffer_size = 768K
read_buffer = 2M
write_buffer = 2M

[mysqlhotcopy]
interactive-timeout
创建mysql 容器命令
docker run -p 3306:3306 -d --name mysql -v D:\docker\mysql\my.cnf:/etc/mysql/my.cnf --privileged=true -e MYSQL_ROOT_PASSWORD=root mysql

-d 后台运行(守护进程)
--name mysql:将容器命名为mysql
-v 将主机中的mysql配置挂载到容器的 /etc/mysql/my.cnf
-p 3306:3306 :将容器的3306端口映射到主机的3306端口

数据库 配置自己的用户
[root@localhost docker]# docker exec -it mysql bash
root@0ead771c95b4:/#

#连接mysql,密码就是我们在构建容器时镜像设置的MYSQL_ROOT_PASSWORD参数值
root@0ead771c95b4:/# mysql -uroot -p
Enter password:
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 11
Server version: 8.0.24 MySQL Community Server - GPL

Copyright (c) 2000, 2021, Oracle and/or its affiliates.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql>
mysql> create user `starsky`@`%` identified by "root";
mysql> grant all on *.* to `starsky`@`%` with grant option;

本地navcat 链接数据库

host   localhost 或 127.0.0.1

其余正常填写

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值