1.安装mysql

$ docker run -d --name mysql \
> -v d_mysql:/var/lib/mysql \
> -e MYSQL_ROOT_PASSWORD=password \
> -e MYSQL_DATABASE=nextcloud \
> -e MYSQL_USER=nextcloud \
> -e MYSQL_PASSWORD=password \
> -p 3306:3306 \
> mysql:8.0

说一下这几个选项:

-d选项是让容器以守护态,这样容器就不会自己停止了;–name为容器指定一个名称;-v为数据库映射一个数据卷,d_mysql为本地的一个目录,这样做方便对数据进行本分和迁移;之后四个环境变量分别设置了root用户的密码、新建一个数据库、新建一个用户以及该用户的密码。这里新建的用户对新建的数据库拥有所有权限。然后-p指定端口映射。 MySQL就这样配置完了.

进入其中简单测试一下是不是安装成功了:

$ docker exec -it mysql bash
root@9f49cbe4a285:/# mysql -unextcloud -p
Enter password:
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| nextclud           |
+--------------------+
2 rows in set (0.00 sec)

2.安装next cloud

$ docker run -d --name nextcloud \
-v nextcloud:/var/www/html \
--link mysql:mysql \
-p 8080:80 nextcloud

–link将两个容器连接,这样nextcloud就会直接使用mysql容器作为数据库了。同样-p指定端口,8080是服务器对外开放的端口,网盘都是自己使用登陆的,建议不要选热门端口就行。除此之外,还要确保该端口是打开的,否则访问时会被拒绝;可以用命令行的方式或者云服务器可以更简单一些,直接在安全组中将对应端口开放。 现在,就可以在浏览器上访问了。首次打开会是一个管理员注册页面,数据库选择mysql/MariaDB即可,注意host栏不用填写地址,填写mysql就行。 一般来说到这里就结束了,但是我这里出现了一个错误:

验证不正确,但是在终端是可以正确访问。查了一下,得知是由于MySQL 8默认使用了新的密码验证插件:caching_sha2_password,而之前的PHP版本中所带的mysqlnd无法支持这种验证。 解决这个问题,有两种办法:一种办法是升级PHP支持MySQL 8的新验证插件,但是操作会麻烦一些;另一种是修改MySQL用户的验证,这就简单多了:

$ docker exec -it mysql bash
root@9f49cbe4a285:/# mysql -uroot -p

mysql> ALTER USER 'nextcloud'@'%' IDENTIFIED WITH mysql_native_password BY 'new_password';
Query OK, 0 rows affected (0.02 sec)

mysql> flush privileges;

在这里插入图片描述

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐