测试主从复制是否成功:
可以在Navicat中主库的链接创建一个新的数据库,然后刷新从库的链接,看看有没有更新主库新创建的数据库
读写分离:
面对日益增加的系统访问量,数据库的吞吐量面临着巨大瓶颈。对于同一时刻有大量并发读写操作和较少写操作类型的应用系统来说,将数据库拆分为主库和从库,主库负责处理事务性的增删改操作,从库负责处理查询操作,能够有效的避免由数据更新导致的行锁,使得整个系统的查询性能得到极大的改善。
Sharding-JDBC介绍:
- Sharding-JDBC定位为轻量级Java框架,在Java的JDBC层提供额外服务。它使用客户端直连数据库,以jar包形式提供服务,无需额外部署和依赖,可以理解为增强版的JDBC驱动,完全兼容JDBC和各种ORM框架。
- 使用Sharding-JDBC可以在程序中轻松的实现数据库读写分离
- 适用于任何基于JDBC的ORM框架,如:JPA,Hibernate,Mybatis,Spring JDBC Template或直接使用JDBC
- 支持任何第三方的数据库连接池,如:DBCP,C3P0,BoneCp,Druid,HikariCP等。
- 支持任意实现JDBC规范的数据库。目前支持MySQL,Oracle,SQLServer,PostgreSQL以及任何遵循SQL92标准的数据库
org.apache.shardingsphere
sharding-jdbc-spring-boot-starter
4.0.0-RC1
读写分离案例:
使用Sharding-JDBC实现读写分离步骤:
1、导入maven坐标
---------------------------------------------------
<dependency>
<groupId>org.apache.shardingsphere</groupId>
<artifactId>sharding-jdbc-spring-boot-starter</artifactId>
<version>4.0.0-RC1</version>
</dependency>
---------------------------------------------------
2、在配置文件中配置读写分离规则
---------------------------------------------------
spring:
shardingsphere:
datasource:
names:
master,slave
# 主数据源
master:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://192.168.66.100:3306/rw?characterEncoding=utf-8
username: root
password: root
# 从数据源
slave:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://192.168.66.101:3306/rw?characterEncoding=utf-8
username: root
password: root
masterslave:
# 读写分离配置
load-balance-algorithm-type: round_robin #轮询,从库负载均衡的策略
# 最终的数据源名称
name: dataSource
# 主库数据源名称
master-data-source-name: master
# 从库数据源名称列表,多个逗号分隔
slave-data-source-names: slave
props:
sql:
show: true #开启SQL显示,默认false
---------------------------------------------------
3、在配置文件中配置允许bean定义覆盖配置项
---------------------------------------------------
main:
allow-bean-definition-overriding: true //允许bean定义覆盖,默认为false
---------------------------------------------------
项目实现读写分离:
- 数据库环境准备(主从复制):
- 直接使用我们前面在虚拟机中搭建的主从复制的数据库环境即可
- 在主库中创建项目的业务数据库并导入相关表格结构和数据
1、数据库环境准备(主从复制):
直接使用我们前面在虚拟机中搭建的主从复制的数据库环境即可
在主库中创建项目的业务数据库并导入相关表格结构和数据
2、代码改造:
1、导入maven坐标
2、在配置文件中配置读写分离规则
3、在配置文件中配置允许bean定义覆盖配置项
Nginx:
- Nginx是一款轻量级的Web服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。其特带你是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx的网站有:百度、京东、新浪、网易、腾讯、淘宝等。
- Nginx是有由伊戈尔·塞索耶夫为俄罗斯访问量第二的Rambler.ru站点开发的,第一个公开版本0.1.0发布于2004年10月4日
- 官网:https:nginx.org/
Nginx下载和安装:
可以到Nginx官方网站下载Nginx的安装包,地址为:https://nginx.org/en/download.html
安装过程:
1、下载依赖包:yum -y install gcc pcre-devel zlib-devel openssl openssl-devel
2、下载Nginx安装包:wget https://nginx.org/download/nginx-1.16.1.tar.gz
若wget不存在,先yum install wget
3、解压:tar -zxvf nginx-1.16.1.tar.gz
4、cd nginx-1.16.1
5、 mkdir -p /usr/local/nginx
./configure --prefix=/usr/local/nginx
6、make && make install
Nginx目录结构:
重点目录/文件:
conf/nginx.conf: nginx配置文件
html: 存放静态文件(html,css,js等)
logs: 日志目录,存放日志文件
sbin/nginx: 二进制文件,用于启动、停止Nginx服务
Nginx命令:
1、./nginx -v (sbin目录下执行):查看Nginx版本
2、./nginx -t (sbin目录下执行):在启动Nginx服务之前,可以先检查一下conf/nginx.conf文件配置的是否有错误
-----------------------------------
正确情况:
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful
-----------------------------------
3、./nginx(sbin目录下执行):启动Nginx服务
4、./nginx -s stop(sbin目录下执行):停止Nginx服务
可以使用绝对路径写法:/usr/local/nginx/sbin/nginx -s stop
5、ps -ef | grep nginx:启动完成后可以查看Nginx
重新加载配置文件:
当修改Nginx配置文件后,需要重新加载才能生效,可以使用下面命令重新加载配置文件:./nginx -s reload
为了方便执行命令,把nginx的二进制文件路径配置到系统的环境变量里,这样的话不管在哪个路径下都可以执行ignix命令:
------------------------------------
vim /etc/profile
PATH=/usr/local/nginx/sbin:$JAVA_HOME/bin:$PATH
:wq
source /etc/profile
------------------------------------
Nginx配置文件(conf/nginx.conf)整体分为三部分:
全局块:和Nginx运行相关的全局配置
events块:和网络链接相关的配置
http块:代理、缓存、日志记录、虚拟主机配置
http全局块
Server块
Server全局块
location块
注意:http块中可以配置多个Server块,每隔Server块中可以配置多个location块
cd /usr/local/nginx/conf
Nginx部署静态资源:
1、Nginx可以作为静态web服务器来部署静态资源。静态资源指在服务端真识存在并且能够直接展示的一些文件,比如常见的html页面、css文件、js文件、图片、视频等资源
2、相对于Tomcat,Nginx处理静态资源的能力更加高效,所以在生产环境下,一般都会将静态资源部署到Nginx中。
3、将静态资源部署到Nginx非常简单,只需要将文件复制到Nginx安装目录下的html目录中即可。
---------------------------------------------
server{
listen 80; #监听端口
server_name localhost; #服务器名称
location/{ #匹配客户端请求url
root html; #指定静态资源根目录
index index.html; #指定默认首页
}
}
---------------------------------------------