越来越多的公司采用springcloud开发项目,springcloud是微服务架构最好的落地实现。一个大型复杂软件应用由一个或多个微服务组成。系统中的各个微服务可被独立部署,各个微服务之间是松耦合的。每个微服务仅关注于完成一件任务并很好地完成该任务。在所有情况下,每个任务代表着一个小的业务能力。使用springcloud不可避免要部署很多的相关服务,如数据库、文件服务器、各个微服务、Nginx、Redis缓存服务等等。当然正式环境这些肯定会分离部署到很多台服务器上。但是这也决定了我们的springcloud项目不便于迁移。各个中间件都缺一不可。下面我们就使用docker搭建一套springcloud基础镜像。这样如果我们要测试或者迁移。直接从基础镜像入手,放入我们的微服务jar包,然后执行脚本就可以成功运行我们的微服务。
1. 构建centos基础容器
1. docker search centos 2. docker pull docker.io/centos 3. docker images
然后构建基础镜像
docker run -itd --name centos-test --privileged 0d120b6ccaa8 /usr/sbin/init
这里要加上--privileged,不然无法在docker容器内使用systemctl
2. 安装JDK
# 检索1.8的列表 yum list java-1.8* # 安装1.8.0 yum install java-1.8.0-openjdk* -y # 检查是否安装成功 java -version
3. 安装Mysql
# 检查系统中是否已安装 MySQL rpm -qa | grep mysql # 查看已安装的 Mariadb 数据库版本 rpm -qa|grep -i mariadb # 卸载已安装的 Mariadb 数据库 rpm -qa|grep mariadb|xargs rpm -e --nodeps # 确认卸载完成 rpm -qa|grep -i mariadb # 下载安装包文件 wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm # 安装mysql的rpm rpm -ivh mysql-community-release-el7-5.noarch.rpm # 安装mysql yum install mysql-server # 检查mysql是否安装成功 rpm -qa | grep mysql #启动 mysql 服务 systemctl start mysqld.service #启动 mysql systemctl restart mysqld.service #重启 mysql systemctl stop mysqld.service #停止 mysql systemctl enable mysqld.service #设置 mysql 开机启动
mysql常用的配置文件
/etc/my.cnf 这是mysql的主配置文件 /var/lib/mysql mysql数据库的数据库文件存放位置 /var/logs/mysqld.log 数据库的日志输出存放位置
修改密码,可以先用select user,host from user; 查看用户对应的是localhost还是 @
再执行alert命令@‘localhost’或者‘%’。 不然会报
错误 1396 (HY000):对“root”@“本地主机”操作更改用户失败
# mysql -u root mysql> use mysql; mysql> select user,host from user; mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '123'; mysql> flush privileges;
4. 安装Redis
安装Redis
1. yum install redis 2. yum install epel-release
Redis服务管理
# 启动Redis systemctl start redis # 查看Redis状态 systemctl status redis # 停止服务 systemctl stop redis # 重启服务 systemctl restart redis # 设置开机自启动 systemctl enable redis # 开放端口号 firewall-cmd --zone=public --add-port=80/tcp --permanent firewall-cmd --zone=public --add-port=6379/tcp --permanent # 查看端口 netstat -lnp|grep 6379
设置Redis远程连接和密码
vi /etc/redis.conf
1. 注释掉bind 127.0.0.1。 将这部注释掉,否则只有本机才能访问
2. 保护模式修改为no。 protecteted-mode no
3. 修改密码。 requirepass 123456
保存完重启服务。
5. 安装Fastdfs
1. 安装编译环境
yum install git gcc gcc-c++ make automake autoconf libtool pcre pcre-devel zlib zlib-devel openssl-devel
2. 磁盘存放目录
1. mkdir /home/dfs #创建数据存储目录 2. cd /usr/local/src #切换到安装目录准备下载安装包
3. 安装libfatscommon
git clone https://github.com/happyfish100/libfastcommon.git --depth 1 cd libfastcommon/ ./make.sh && ./make.sh install #编译安装
4. 安装fastdfs
cd ../ #返回上一级目录 git clone https://github.com/happyfish100/fastdfs.git --depth 1 cd fastdfs/ ./make.sh && ./make.sh install #编译安装 #配置文件准备 cp /etc/fdfs/tracker.conf.sample /etc/fdfs/tracker.conf cp /etc/fdfs/storage.conf.sample /etc/fdfs/storage.conf cp /etc/fdfs/client.conf.sample /etc/fdfs/client.conf #客户端文件,测试用 cp /usr/local/src/fastdfs/conf/http.conf /etc/fdfs/ #供nginx访问使用 cp /usr/local/src/fastdfs/conf/mime.types /etc/fdfs/ #供nginx访问使用
5. 安装fastdfs-nginx-module
cd ../ #返回上一级目录 git clone https://github.com/happyfish100/fastdfs-nginx-module.git --depth 1 cp /usr/local/src/fastdfs-nginx-module/src/mod_fastdfs.conf /etc/fdfs
6. 安装Nginx
wget http://nginx.org/download/nginx-1.15.4.tar.gz #下载nginx压缩包 tar -zxvf nginx-1.15.4.tar.gz #解压 cd nginx-1.15.4/ #添加fastdfs-nginx-module模块 ./configure --add-module=/usr/local/src/fastdfs-nginx-module/src/ make && make install #编译安装
7. 单机部署配置
tracker配置
#服务器ip为 192.168.0.104 vim /etc/fdfs/tracker.conf #需要修改的内容如下 port=22122 # tracker服务器端口(默认22122,一般不修改) base_path=/home/dfs # 存储日志和数据的根目录
storage配置
vim /etc/fdfs/storage.conf #需要修改的内容如下 port=23000 # storage服务端口(默认23000,一般不修改) base_path=/home/dfs # 数据和日志文件存储根目录 store_path0=/home/dfs # 第一个存储目录 tracker_server=192.168.0.104:22122 # tracker服务器IP和端口 http.server_port=8888 # http访问文件的端口(默认8888,看情况修改,和nginx中保持一致)
配置nginx访问
vim /etc/fdfs/mod_fastdfs.conf #需要修改的内容如下 tracker_server=192.168.0.104:22122 #tracker服务器IP和端口 url_have_group_name=true store_path0=/home/dfs #配置nginx.config vim /usr/local/nginx/conf/nginx.conf #添加如下配置 server { listen 8888; ## 该端口为storage.conf中的http.server_port相同 server_name localhost; location ~/group[0-9]/ { ngx_fastdfs_module; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } }