分类 高可用架构 下的文章

MySQL 从属数据库配置

1:前提

  • 新建一台服务器

2:配置主服务器

  • 配置文件 打开server-id&log-bin注释
  • 新建一行relay-log复制log-bin=
  • 在数据库添加用户和权限
  • show master status 获取到file&postion信息

3:配置从服务器

  • 注释掉bind-address
  • 配置文件 修改server-id=2&log-bin
  • 新建一行relay-log复制log-bin=
  • 创建一个同名数据库

mysql> CHANGE MASTER TO MASTER_HOST='server1',

    -> MASTER_USER='repl',
    -> MASTER_PASSWORD='p4ssword',
    -> MASTER_LOG_FILE='mysql-bin.000001',
    -> MASTER_LOG_POS=0;
  • START SLAVE

4:配置防火墙

参考:

Redis 缓存服务器

1:安装redis(ubuntu环境)

  • apt-get install redis-server

2:修改配置

  • redis-conf配置文件
  • bind绑定内网IP
  • 重启redis

3:好处

  • 配置 Redis 缓存服务器作为单独分离的缓存来用
  • 单一行

单台MySQL服务器配置

1:MySQL服务器配置

  • 找到mysql的配置文件
  • bind-address 改为绑定自己的服务器内网ID
  • 应用服务器才可以绑定这个数据库

2:添加用户和权限

  • 命令:CREATE USER 'username'@'host' IDENTIFIED BY 'password';

例子:
CREATE USER 'dog'@'localhost' IDENTIFIED BY '123456';
CREATE USER 'dog2'@'localhost' IDENTIFIED BY '';
username - 你将创建的用户名,
host - 指定该用户在哪个主机上可以登陆,此处的"localhost",是指该用户只能在本地登录,不能在另外一台机器上远程登录,如果想远程登录的话,将"localhost"改为"%",表示在任何一台电脑上都可以登录;也可以指定某台机器可以远程登录;
password - 该用户的登陆密码,密码可以为空,如果为空则该用户可以不需要密码登陆服务器。

  • 分配权限:GRANT privileges ON databasename.tablename TO 'username'@'host'

例子: GRANT SELECT, INSERT ON mq.* TO 'dog'@'localhost';
privileges - 用户的操作权限,如SELECT , INSERT , UPDATE 等(详细列表见该文最后面).如果要授予所的权限则使用ALL.;databasename - 数据库名,tablename-表名,如果要授予该用户对所有数据库和表的相应操作权限则可用表示, 如.*.

3:连接数据库

  • 将多台应用服务器下的项目连接到数据库
  • 进行测试连接

4:总结

通过配置单独的 MySQL 服务器,我们可以实现数据库与应用服务器的分离,保证服务的单一性

项目部署同时到多台服务器

1:Envoy 部署工具 => 针对laravel框架

Laravel Envoy 为定义远程服务器的日常任务,提供了一套简洁、轻量的语法。Blade 风格语法即可实现部署任务的配置、Artisan 命令的执行等。目前,Envoy 仅支持 Mac 和 Linux 操作系统

  • composer global require laravel/envoy
  • composer global update
  • 在根目录新建文件Envoy.blade.php
  • 多服务器

    @servers(['web-1' => '192.168.1.1', 'web-2' => '192.168.1.2'])

  • 并行运行

    @task('deploy', ['on' => ['web-1', 'web-2'], 'parallel' => true])
    cd site
    git pull origin {{ $branch }}
    php artisan migrate
    @endtask

  • 运行任务:envoy run task

2: Deployer 部署工具

安装
composer require deployer/deployer --dev
初始化 deployer 配置文件

参考:

Nginx负载均衡配置与负载策略

1: 原理

负载均衡的目的是为了解决单个节点压力过大,造成Web服务响应过慢,严重的情况下导致服务瘫痪,无法正常提供服务

2:内置负载策略

Nginx负载均衡是通过upstream模块来实现的,内置实现了三种负载策略,配置还是比较简单的。

  • 轮循(默认)

Nginx根据请求次数,将每个请求均匀分配到每台服务器

  • 最少连接

将请求分配给连接数最少的服务器。Nginx会统计哪些服务器的连接数最少。

  • IP Hash

绑定处理请求的服务器。第一次请求时,根据该客户端的IP算出一个HASH值,将请求分配到集群中的某一台服务器上。后面该客户端的所有请求,都将通过HASH算法,找到之前处理这台客户端请求的服务器,然后将请求交给它来处理

http {
    #例1 ... 省略其它配置
    upstream tomcats {
        server 192.168.0.100:8080;
        server 192.168.0.101:8080;
        server example.com:8080;
    }
    #例2 加权重
    upstream tomcats {
        server 192.168.0.100:8080 weight=2;  # 2/6次
        server 192.168.0.101:8080 weight=3;  # 3/6次
        server 192.168.0.102:8080 weight=1;  # 1/6次
    }

    server {
        listen 80;

        location / {
            proxy_pass http://tomcats;
        }
    }
}

转载:

Nginx 实现负载均衡

1:准备几台服务器或者本地环境创建几台虚拟机

  • 第一台服务器:负载均衡ab-bl
  • 第二台服务器:应用服务器app1
  • 第三台服务器:应用服务器app2

2:登录

  • ssh root@IP地址

3: 安装nginx 作为请求的转发

sudo apt-get update

sudo LC_ALL=en_US.UTF-8 add-apt-repository ppa:nginx/development -y
sudo apt-get update
sudo apt-get -y install nginx

sudo cp /etc/nginx/sites-available/default /etc/nginx/sites-available/default.bak

sudo service nginx start

4: 配置nginx转发配置

upstream backend {
    server pravite-ip-address-1;
    server pravite-ip-address-2;
}

server {
    listen 80 default_server;
    listen [::]:80 default_server;
    server_name nuli.io www.nuli.io;

    location / {

        proxy_pass http://backend;
        proxy_redirect off;
    }

}
保存退出
nginx -t

5:配置应用服务器

  • 安装lnmp环境:命令行 wget 脚本
  • 命令行: bash laravel-app-server.sh