失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > 谷粒商城项目篇1_分布式基础篇_分布式基础概念 环境搭建 创建项目

谷粒商城项目篇1_分布式基础篇_分布式基础概念 环境搭建 创建项目

时间:2024-07-09 19:17:56

相关推荐

谷粒商城项目篇1_分布式基础篇_分布式基础概念 环境搭建 创建项目

写在前面

为丰富项目经验,特此学习B站开源视频《全网最强电商教程《谷粒商城》对标阿里P6/P7,40-60万年薪》希望通过此学习能巩固所学,将技术栈串接起来。

此项目三个阶段

分布式基础:SpringBoot、SpringCloud、Nacos、openFeign、Mybatis、Docker、vue、ElementUI等分布式高级:ES全文检索、业务追踪、缓存Session同步方案、网关、远程调用、线程池、调优、分布式锁、分布式事务、服务限流、熔断、降级等高可用集群:k8s集群、DevOps、redis、mysql、es等的集群搭建部署

开学即大三,离春招秋招越来越近…努力吧

目录

分布式基础概念环境搭建 docker安装mysqldocker安装redis开发环境统一 配置maven阿里云镜像和jdk编译环境vscode安装插件 创建项目 创建聚合总模块创建商品微服务模块创建其他微服务模块修改聚合模块pom配置

一、分布式基础概念

往期 《微服务架构》 系列博客参考:/qq_24654501/category_10935575.html

微服务架构

将单体应用拆分为若干个小服务,每个小服务运行在自己的进程,并使用轻量级机制通信。简而言之,解决大型单体应用,基于业务边界进行服务微化拆分,个个服务独立部署运行。

集群、分布式概念

集群是物理形态,一堆机器就可以叫集群。将几台服务器集中起来实现同一业务。分布式是工作方式,分布式是若干独立计算机的集合,这些计算机相对于用户来说就像单个相关系统(用户体现不到是多个服务器)京东是一个分布式系统,众多业务运行在不同的机器,所有业务构成一个大型的业务集群。

远程调用、负载均衡

在分布式系统中,各个服务可能处于不同的主机,但是服务之间需要通信,SpringCloud中使用 HTTP+JSON的方式完成远程调用。远程调用的过程中,各个服务可能处于不同的主机,怎么使用这些不同的主机保证负载均衡(轮询、权重、最小连接)。

服务的注册、发现

A服务调用B服务,A服务并不知道B服务情况(部署在哪几台机器,是否正常等问题)。为解决这个问题,引入注册中心。

配置中心

每一个服务都需要大量的配置,并且部署在不同的服务器上。变更修改配置非常不方便。因此可以是用配置中心集中管路微服务的配置信息,各个微服务只要去指定地点读取配置即可。

服务熔断、降级

微服务架构中,微服务之间互相存在依赖,当其中一个服务不可用时,有可能会造成雪崩的效应。为了防止这样的情况,需要有 容错机制 保护。服务熔断:设置服务的超时时间,当被调用的服务经常失败到达某个阀值,可以开启断路保护机制,后来的请求不在远程调用这个故障服务,直接调用调用者本地直接返回默认数据。服务降级:在运维期间,系统处于高峰期,系统资源紧张,我们可以让非核心业务降级运行。(降级:不处理或者简单处理,抛异常、返回null、调用mock数据、调用Fallback处理逻辑)

API网关

微服务架构中重要的组件,他抽象了微服务中华都需要的公共功能,同时提供客户端负载均衡、服务自动熔断、灰度发布、同一认证、限流流控、日志统计等丰富的功能。对于前后端分离的微服务来说,前端发送json数据请求到后端,都要先通过API网关。

微服务架构图

微服务划分图

二、环境搭建

步骤

使用VirtualBox + vagrant 创建Linux虚拟机(因为我使用阿里云服务器,此步骤省略)安装docker,后续使用mysql、redis等都使用docker安装。参考往期博客《Docker学习篇1_Docker概述、Docker安装、Run的流程和Docker原理、Docker常用命令、Docker安装Nginx、tomcat练习》

centos官网安装dokcer步骤:/engine/install/centos/

启动、设置开机自启

# 启动docker[root@iZ2vc8owmlobwkazif1efpZ /]# sudo systemctl start docker[root@iZ2vc8owmlobwkazif1efpZ /]# docker -vDocker version 20.10.7, build f0df350[root@iZ2vc8owmlobwkazif1efpZ /]# docker imagesREPOSITORY TAG IMAGE ID CREATED SIZE# 设置开机自启[root@iZ2vc8owmlobwkazif1efpZ /]# sudo systemctl enable dockerCreated symlink from /etc/systemd/system/multi-user.target.wants/docker.service to /usr/lib/systemd/system/docker.service.[root@iZ2vc8owmlobwkazif1efpZ /]#

配置阿里云镜像加速

[root@iZ2vc8owmlobwkazif1efpZ /]# sudo mkdir -p /etc/docker[root@iZ2vc8owmlobwkazif1efpZ /]# sudo tee /etc/docker/daemon.json <<-'EOF'> {> "registry-mirrors": ["https://rkbc9ion."]> }> EOF{"registry-mirrors": ["https://rkbc9ion."]}[root@iZ2vc8owmlobwkazif1efpZ /]# sudo systemctl daemon-reload[root@iZ2vc8owmlobwkazif1efpZ /]# sudo systemctl restart docker[root@iZ2vc8owmlobwkazif1efpZ /]#

1.安装MySQL

拉去镜像:docker pull mysql:5.7

创建实例运用卷挂载并启动docker run

docker run -p 3306:3306 --name mysql \-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 ps

# 挂载启动mysql# -v 指定 卷挂载,分别挂载日志、配置文件夹到主机# -e 设置初始密码# -d Run container in background and print container ID[root@iZ2vc8owmlobwkazif1efpZ /]# docker run -p 3306:3306 --name mysql \> -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.796f1910989d54192037d8ebdc6973fec4eb20f5a8060b0f526b074c37e8a1eb1# 查看启动[root@iZ2vc8owmlobwkazif1efpZ /]# docker psCONTAINER ID IMAGE COMMAND CREATED STATUS PORTSNAMES96f1910989d5 mysql:5.7 "docker-entrypoint.s…" 4 minutes ago Up 4 minutes 0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp mysql

命令行交互方式进入容器docker exec -it 容器ID/bin/bash

[root@iZ2vc8owmlobwkazif1efpZ /]# docker psCONTAINER ID IMAGE COMMAND CREATED STATUS PORTSNAMES96f1910989d5 mysql:5.7 "docker-entrypoint.s…" 9 minutes ago Up 9 minutes 0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp mysql# 进入容器内部,其实一个容器好比一个Linux系统[root@iZ2vc8owmlobwkazif1efpZ /]# docker exec -it 96f1910989d5 /bin/bashroot@96f1910989d5:/# lsbin boot devdocker-entrypoint-initdb.d entrypoint.sh etchome lib lib64 media mnt opt proc root run sbin srv sys tmp usr var# 查看mysql的安装目录root@96f1910989d5:/# whereis mysqlmysql: /usr/bin/mysql /usr/lib/mysql /etc/mysql /usr/share/mysqlroot@96f1910989d5:/#

查看本地挂载的mysql配置文件夹

[root@iZ2vc8owmlobwkazif1efpZ /]# lsbin boot dev etc home lib lib64 lost+found media mnt mydata opt proc root run sbin srv sys tmp usr var[root@iZ2vc8owmlobwkazif1efpZ /]# cd /mydata/[root@iZ2vc8owmlobwkazif1efpZ mydata]# lsmysql[root@iZ2vc8owmlobwkazif1efpZ mydata]# cd ./mysql/[root@iZ2vc8owmlobwkazif1efpZ mysql]# lsconf data log[root@iZ2vc8owmlobwkazif1efpZ mysql]# cd ./conf/[root@iZ2vc8owmlobwkazif1efpZ conf]# ls[root@iZ2vc8owmlobwkazif1efpZ conf]# cd ../data[root@iZ2vc8owmlobwkazif1efpZ data]# ls96f1910989d5.pid ca-key.pem client-cert.pem ib_buffer_pool ib_logfile0 ibtmp1 performance_schema public_key.pem server-fca.pemclient-key.pem ibdata1 ib_logfile1 mysql private_key.pemserver-cert.pem sys[root@iZ2vc8owmlobwkazif1efpZ data]# cd ../log/[root@iZ2vc8owmlobwkazif1efpZ log]# ls[root@iZ2vc8owmlobwkazif1efpZ log]#

配置mysql

vi /mydata/mysql/conf/f[client]default-character-set=utf-8[mysqld]init_connect='SET collation_connection=utf8_unicode_ci'init_connect='SET NAMES utf8'character-set-server=utf8collation-server=utf8_unicode_ciskip-character-set-client-handshakeskip-name-resolve

[root@iZ2vc8owmlobwkazif1efpZ mysql]# docker psCONTAINER ID IMAGE COMMAND CREATEDSTATUSPORTSNAMES96f1910989d5 mysql:5.7 "docker-entrypoint.s…" 26 minutes ago Up 13 seconds 0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp mysql[root@iZ2vc8owmlobwkazif1efpZ mysql]# docker restart 96f1910989d596f1910989d5[root@iZ2vc8owmlobwkazif1efpZ mysql]# docker psCONTAINER ID IMAGE COMMAND CREATEDSTATUS PORTSNAMES96f1910989d5 mysql:5.7 "docker-entrypoint.s…" 26 minutes ago Up 4 seconds 0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp mysql[root@iZ2vc8owmlobwkazif1efpZ mysql]# docker exec -it 96f1910989d5 /bin/bashroot@96f1910989d5:/# lsbin boot devdocker-entrypoint-initdb.d entrypoint.sh etchome lib lib64 media mnt opt proc root run sbin srv sys tmp usr var# 查看容器内配置目录,是否挂在成功是否存在froot@96f1910989d5:/# cd /etc/mysql/root@96f1910989d5:/etc/mysql# froot@96f1910989d5:/etc/mysql# cat f [client]default-character-set=utf-8[mysql]default-character-set=utf-8[mysqld]init_connect='SET collation_connection=utf8_unicode_ci'init_connect='SET NAMES utf8'character-set-server=utf8collation-server=utf8_unicode_ciskip-character-set-client-handshakeskip-name-resolveroot@96f1910989d5:/etc/mysql#

2.安装Redis

基本步骤

拉去镜像

挂载启动

测试

[root@iZ2vc8owmlobwkazif1efpZ mysql]# docker pull redis[root@iZ2vc8owmlobwkazif1efpZ mysql]# docker imagesREPOSITORY TAG IMAGE ID CREATED SIZEmysql 5.7 9f1d21c1025a 2 days ago 448MBredis latest 08502081bff6 4 weeks ago 105MB# 直接写redis.conf挂在会被当做目录,需要先创建主机挂载文件夹[root@iZ2vc8owmlobwkazif1efpZ conf]# touch redis.conf[root@iZ2vc8owmlobwkazif1efpZ conf]# lsredis.conf# 执行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# 测试,相比于mysql的/bin/bash,可以使用redis-cli测试[root@iZ2vc8owmlobwkazif1efpZ redis]# docker psCONTAINER ID IMAGE COMMAND CREATEDSTATUSPORTSNAMESf26a09fb394e redis "docker-entrypoint.s…" 6 seconds ago Up 5 seconds 0.0.0.0:6379->6379/tcp, :::6379->6379/tcp redis96f1910989d5 mysql:5.7 "docker-entrypoint.s…" 42 minutes ago Up 15 minutes 0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp mysql# 重启容器[root@iZ2vc8owmlobwkazif1efpZ conf]# docker restart redisredis[root@iZ2vc8owmlobwkazif1efpZ conf]# cd /mydata/redis/conf/[root@iZ2vc8owmlobwkazif1efpZ conf]# lsredis.conf# redis.conf现在还是空的,待会配置持久化[root@iZ2vc8owmlobwkazif1efpZ conf]# cat redis.conf [root@iZ2vc8owmlobwkazif1efpZ conf]# docker exec -it redis redis-cli127.0.0.1:6379> pingPONG127.0.0.1:6379>

配置aof持久化

[root@iZ2vc8owmlobwkazif1efpZ conf]# vi redis.conf [root@iZ2vc8owmlobwkazif1efpZ conf]# cat redis.conf appendonly yes[root@iZ2vc8owmlobwkazif1efpZ conf]# docker restart redisredis[root@iZ2vc8owmlobwkazif1efpZ conf]# docker exec -it redis redis-cli127.0.0.1:6379> set name xiaosiOK127.0.0.1:6379> get name"xiaosi"127.0.0.1:6379> exit[root@iZ2vc8owmlobwkazif1efpZ conf]# docker restart redisredis[root@iZ2vc8owmlobwkazif1efpZ conf]# docker exec -it redis redis-cli127.0.0.1:6379> get name"xiaosi"127.0.0.1:6379>

本地连接测试

最后将mysql、redis设置为docker启动时自启

5.开发环境统一
JDK的版本环境为11Maven的版本为3.6.3
1.配置Maven阿里云镜像和jdk的编译环境

步骤

打开Maven的配置文件,我的E:\Maven\apache-maven-3.6.3-bin\apache-maven-3.6.3\conf

配置默认jdk环境

IDEA整合Maven

2.vscode安装插件

三、创建项目

微服务模块

商品服务仓储服务订单服务优惠券服务用户服务

1.创建总模块
创建git仓库

使用git地址/GitHubSi/guli-shop初始化IDEA项目,作为总模块。

2.创建商品微服务模块

3.创建其他各个微服务模块

最后

4.修改聚合模块pom配置

最后push到仓库

仓库地址:/GitHubSi/guli-shop

如果觉得《谷粒商城项目篇1_分布式基础篇_分布式基础概念 环境搭建 创建项目》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。