1、概述

上篇文章《架构设计:负载均衡层设计方案(6)——Nginx + Keepalived构建高可用的负载层》(http://blog.csdn.net/yinwenjie/article/details/47130609) 我们讲解了Nginx的故障切换,并且承诺各位读者会尽快讲解 LVS + Keepalived + Nginx的安装和配置。在中间由于工作的原因,我又插写了三篇关于zookeeper的原理使用的文章。今天这边文章我们回归主题,为各位读者讲解LVS + Keepalived + Nginx的安装及配置。

2、安装计划和准备工作

下图,我们表示了本篇文章要搭建的整个集成架构的抽象结构:

我们采用两个LVS节点(141和142),但是一个时间工作的只有一个LVS节点,另一个始终处于热备standby状态,由keepalived监控这两个节点的工作状态并完成切换。

在LVS节点下,我们采用LVS-DR工作模式挂载了两个Nginx节点(131、132)。并最终将外网请求交由这两个节点进行处理。注意:在实际工作中,Nginx下面一般就是访问静态资源、动态资源的配置了。

2-1、准备两个keepalived节点

首先我们在将要安装LVS的两个节点上,先安装keepalived,并保证这两个keepalived节点能够正常工作(监控批次的状态)。当然,您也可以先准备LVS,在准备keepalived。

我想准备keepalived节点,大家应该轻车熟路了吧,在《架构设计:负载均衡层设计方案(6)——Nginx + Keepalived构建高可用的负载层》这篇文章中详细介绍了keepalived的最简配置方式。为了大家阅读方便,我们在这里再进行依次简要说明。准备keepalived的整个过程包括:

  1. 安装必要的支撑组件,源码安装keepalived
  2. 将keepalived注册成节点的服务,以便保证keepalived在节点启动时就开始工作
  3. 更改keepalived的配置文件,让其可以正常工作
  4. 验证准备工作

=============安装keepalived

  1. [root@lvs1 ~]# yum install -y zlib zlib-devel gcc gcc-c++ openssl openssl-devel openssh
  2. [root@lvs1 ~]# tar -zxvf keepalived-1.2.17.tar.gz
  3. [root@lvs1 ~]# cd keepalived-1.2.17
  4. [root@lvs1 ~]# ./configure --perfix=/usr/keepalived-1.2.17
  5. [root@lvs1 ~]# make & make install
  • 1
  • 2
  • 3
  • 4
  • 5
  • 1
  • 2
  • 3
  • 4
  • 5

=============将keepalived注册成服务(如果您使用的默认路径安装,就不需要cp命令了)

  1. [root@lvs1 ~]# cp /usr/keepalived-1.2.17/etc/sysconfig/keepalived /etc/sysconfig/keepalived
  2. [root@lvs1 ~]# cp /usr/keepalived-1.2.17/sbin/keepalived /usr/sbin/keepalived
  3. [root@lvs1 ~]# cp /usr/keepalived-1.2.17/etc/rc.d/init.d/keepalived /etc/rc.d/init.d/keepalived
  4. [root@lvs1 ~]# mkdir /etc/keepalived
  5. [root@lvs1 ~]# cp /usr/keepalived-1.2.17/etc/keepalived/keepalived.conf /etc/keepalived/keepalived.conf
  6. [root@lvs1 ~]# 可以做成服务了(不要拷贝,没用的)
  7. [root@lvs1 ~]# chkconfig keepalived on
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

做成服务后,先不要急着启动,因为配置文件还没有改好。 
========配置keepalived(配置文件在:/etc/keepalived/keepalived.conf)

  1. ! Configuration File for keepalived
  2. global_defs {
  3. #notification_email {
  4. # acassen@firewall.loc
  5. # failover@firewall.loc
  6. # sysadmin@firewall.loc
  7. #}
  8. #notification_email_from Alexandre.Cassen@firewall.loc
  9. #smtp_server 192.168.200.1
  10. #smtp_connect_timeout 30
  11. router_id LVS_DEVEL
  12. }
  13. vrrp_instance VI_1 {
  14. #141节点设置为MASTER,142或者还有其他的节点设置为BACKUP
  15. #还记得我们前面文章讲到的无抢占设置吗?这里也可以用哦。
  16. state MASTER
  17. #网络适配器名称
  18. interface eth0
  19. virtual_router_id 51
  20. #所有的SLAVE节点的优先级都要比这个设置值低
  21. priority 120
  22. advert_int 1
  23. #真实ip,142要改成相应的lvs节点真实ip
  24. mcast_src_ip=192.168.220.141
  25. authentication {
  26. auth_type PASS
  27. auth_pass 1111
  28. }
  29. #虚拟/浮动IP
  30. virtual_ipaddress {
  31. 192.168.220.140
  32. }
  33. }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35

以上配置还是最简单的keepalived配置,因为我们还没有加上配合LVS使用的虚拟ip监测设置和下层真实ip监测的设置。最简配置主要是为了保证keepalived节点是工作正常的。

将以上的配置分别对应到LVS的两个节点(注意要改动的地方哦)

==========进行keepalived工作状态的检查:

  1. [root@lvs1 ~]# /etc/init.d/keepalived start
  • 1
  • 1

现在设置为MASTER的keepalived节点(或者在非抢占模式下,优先级最高的那个节点),已经绑定了140这个虚拟ip了:

  1. [root@lvs2 ~]# ip addr
  2. 1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue state UNKNOWN
  3. link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
  4. inet 127.0.0.1/8 scope host lo
  5. inet6 ::1/128 scope host
  6. valid_lft forever preferred_lft forever
  7. 2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000
  8. link/ether 00:0c:29:39:75:9f brd ff:ff:ff:ff:ff:ff
  9. inet 192.168.220.141/24 brd 192.168.220.255 scope global eth0
  10. inet 192.168.220.140/32 scope global eth0
  11. inet6 fe80::20c:29ff:fe39:759f/64 scope link
  12. valid_lft forever preferred_lft forever
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

当然您也可以通过 /var/log/message的日志进行keepalived是否正常工作的验证。

2-2、继续两个keepalived节点上准备LVS

准备lvs的工作就太简单了,因为centos6.4、6.5、6.6都已经集成了LVS的核心,我们只需要安装LVS的管理工具就行了:

两个LVS节点都执行:

  1. yum -y install ipvsadm
  • 1
  • 1

还记得lvs管理工具怎么使用吗?请参见我介绍LVS单节点安装的博文:《架构设计:负载均衡层设计方案(5)——LVS单节点安装》。这里为了方便阅读,给出主要参数的含义列表:

  1. -A add-service 在内核的虚拟服务器表中添加一条新的虚拟服务器记录。也就是增加一台新的虚拟服务器。
  2. -E edit-service 编辑内核虚拟服务器表中的一条虚拟服务器记录。
  3. -D delete-service 删除内核虚拟服务器表中的一条虚拟服务器记录。
  4. -C clear 清除内核虚拟服务器表中的所有记录。
  5. -R restore 恢复虚拟服务器规则
  6. -S save 保存虚拟服务器规则,输出为-R 选项可读的格式
  7. -a add-server 在内核虚拟服务器表的一条记录里添加一条新的真实服务器记录。也就是在一个虚拟服务器中增加一台新的真实服务器
  8. -e edit-server 编辑一条虚拟服务器记录中的某条真实服务器记录
  9. -d delete-server 删除一条虚拟服务器记录中的某条真实服务器记录
  10. -L list 显示内核虚拟服务器表
  11. -Z zero 虚拟服务表计数器清零(清空当前的连接数量等)
  12. set tcp tcpfin udp 设置连接超时值
  13. start-daemon 启动同步守护进程。他后面可以是master backup,用来说明LVS Router master 或是backup。在这个功能上也可以采用keepalived VRRP 功能。
  14. stop-daemon 停止同步守护进程
  15. -t tcp-service service-address 说明虚拟服务器提供的是tcp 的服务[vip:port] or [real-server-ip:port]
  16. -u udp-service service-address 说明虚拟服务器提供的是udp 的服务[vip:port] or [real-server-ip:port]
  17. -f fwmark-service fwmark 说明是经过iptables 标记过的服务类型。
  18. -s scheduler scheduler 使用的调度算法,选项:rr|wrr|lc|wlc|lblc|lblcr|dh|sh|sed|nq, 默认的调度算法是: wlc.
  19. -p persistent [timeout] 持久稳固的服务。这个选项的意思是来自同一个客户的多次请求,将被同一台真实的服务器处理。timeout 的默认值为300 秒。
  20. -M netmask netmask persistent granularity mask
  21. -r real-server server-address 真实的服务器[Real-Server:port]
  22. -g gatewaying 指定LVS 的工作模式为直接路由模式DR模式(也是LVS默认的模式)
  23. -i ipip 指定LVS 的工作模式为隧道模式
  24. -m masquerading 指定LVS 的工作模式为NAT 模式
  25. -w weight weight 真实服务器的权值
  26. mcast-interface interface 指定组播的同步接口
  27. connection 显示LVS 目前的连接 如:ipvsadm -L -c
  28. timeout 显示tcp tcpfin udp timeout 如:ipvsadm -L timeout
  29. daemon 显示同步守护进程状态
  30. stats 显示统计信息
  31. rate 显示速率信息
  32. sort 对虚拟服务器和真实服务器排序输出
  33. numeric -n 输出IP 地址和端口的数字形式
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33

到后面正式启动LVS的时候,就不要问我参数含义咯。^_^

2-3、准备两个Nginx节点并保证可用

在《架构设计:负载均衡层设计方案(5)——LVS单节点安装》(http://blog.csdn.net/yinwenjie/article/details/47010569) 这篇文章中,我们详细讲解了Nginx节点的准备工作,但是为了方便各位读者阅读,这里我们大致再讲一下。

Nginx节点的准备工作主要由以下步骤构成(这个不是本文的重点,点到即可):

  1. 安装Nginx(当然,正式系统中,还涉及到Nginx的参数调优,可以参见《架构设计:负载均衡层设计方案(2)——Nginx安装》这篇文章
  2. 打开Nginx所在服务器的“路由”功能、关闭“ARP查询”功能
  3. 将VIP:192.168.220.140 设置成Nginx所在节点的回环IP

=============安装Nginx

  1. [root@vm1 ~]# yum -y install make zlib zlib-devel gcc gcc-c++ ssh libtool
  2. [root@vm1 ~]# 下载nginx(别拷贝,不能执行的)
  3. [root@vm1 ~]# 解压nginx(别拷贝,不能执行的)
  4. [root@vm1 ~]# ./configure prefix=/usr/nginx-1.8.0
  5. [root@vm1 ~]# make && make install
  6. [root@vm1 ~]# 设置环境变量(别拷贝,不能执行的)
  7. [root@vm1 ~]# 启动nginx
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

=============打开Nginx所在服务器的“路由”功能、关闭“ARP查询”功能

  1. [root@vm1 ~]# echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore
  2. [root@vm1 ~]# echo "2" >/proc/sys/net/ipv4/conf/lo/arp_announce
  3. [root@vm1 ~]# echo "1" >/proc/sys/net/ipv4/conf/all/arp_ignore
  4. [root@vm1 ~]# echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce
  • 1
  • 2
  • 3
  • 4
  • 1
  • 2
  • 3
  • 4

=============设置回环IP

  1. [root@vm1 ~]# ifconfig lo:0 192.168.220.140 broadcast 192.168.220.140 netmask 255.255.255.255 up
  2. [root@vm1 ~]# route add -host 192.168.220.140 dev lo:0
  • 1
  • 2
  • 1
  • 2

两台Nginx的节点都按照这样的方法去设置。然后使用浏览器,看看这两个节点的Nginx是否工作正常:

=====

2-4、其他说明

keepalived和LVS是天生配合完美的一对,LVS负责进行请求转发不负责任何节点的健康监测;keepalived负责监控整个环境中,包括虚拟ip,真实ip对应的下层节点的健康状态监测

3、开始配置:LVS-DR工作模式

3-1、keepalived的更改——健康监测

首先我们要更改之前配置的“最简keepalived”配置,让keepalived能够对结构中所有节点和虚拟ip的健康状态进行监测。更改配置和含义如下:

  1. ! Configuration File for keepalived
  2. global_defs {
  3. #notification_email {
  4. # acassen@firewall.loc
  5. # failover@firewall.loc
  6. # sysadmin@firewall.loc
  7. #}
  8. #notification_email_from Alexandre.Cassen@firewall.loc
  9. #smtp_server 192.168.200.1
  10. #smtp_connect_timeout 30
  11. router_id LVS_DEVEL
  12. }
  13. vrrp_instance VI_1 {
  14. #141节点设置为MASTER,142或者还有其他的节点设置为BACKUP
  15. #还记得我们前面文章讲到的无抢占设置吗?这里也可以用哦。
  16. state MASTER
  17. #网络适配器名称
  18. interface eth0
  19. virtual_router_id 51
  20. #所有的SLAVE节点的优先级都要比这个设置值低
  21. priority 120
  22. advert_int 1
  23. #真实ip,142要改成相应的lvs节点真实ip
  24. mcast_src_ip=192.168.220.141
  25. authentication {
  26. auth_type PASS
  27. auth_pass 1111
  28. }
  29. #虚拟/浮动IP
  30. virtual_ipaddress {
  31. 192.168.220.140
  32. }
  33. }
  34. virtual_server 192.168.220.140 80 {
  35. #健康时间检查,单位秒
  36. delay_loop 6
  37. #负载均衡调度算法wlc|rr,和您将使用的LVS的调度算法保持原则一致
  38. lb_algo rr
  39. #负载均衡转发规则 DR NAT TUN。和您将启动的LVS的工作模式设置一致
  40. lb_kind DR
  41. #虚拟地址的子网掩码
  42. nat_mask 255.255.255.0
  43. #会话保持时间,因为我们经常使用的是无状态的集群架构,所以这个设置可有可无
  44. #persistence_timeout 50
  45. #转发协议,当然是TCP
  46. protocol TCP
  47. #真实的下层Nginx节点的健康监测
  48. real_server 192.168.220.131 80 {
  49. #节点权重,
  50. weight 10
  51. #设置检查方式,可以设置HTTP_GET | SSL_GET
  52. HTTP_GET {
  53. url {
  54. path /
  55. digest ff20ad2481f97b1754ef3e12ecd3a9cc
  56. }
  57. #超时时间,秒。如果在这个时间内没有返回,则说明一次监测失败
  58. connect_timeout 3
  59. #设置多少次监测失败,就认为这个真实节点死掉了
  60. nb_get_retry 3
  61. #重试间隔
  62. delay_before_retry 3
  63. }
  64. }
  65. real_server 192.168.220.132 80 {
  66. weight 10
  67. HTTP_GET {
  68. url {
  69. path /
  70. digest 640205b7b0fc66c1ea91c463fac6334d
  71. }
  72. connect_timeout 3
  73. nb_get_retry 3
  74. delay_before_retry 3
  75. }
  76. }
  77. }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82

这样一来,keepalived就可以检查整个架构中的所有节点状态了。另外要说明的是,这个检查过程并不是必须的,您使用keepalived的最简配置也是可以的,不过您就需要自己写监测脚本了(道理是一样的)

3-2、启动两个LVS节点

启动LVS的过程就太简单了(两个节点都是一样的启动方式):

  1. [root@lvs2 ~]# ipvsadm -C
  2. [root@lvs2 ~]# ipvsadm -At 192.168.220.140:80 -s rr
  3. [root@lvs2 ~]# ipvsadm -at 192.168.220.140:80 -r 192.168.220.131 -g
  4. [root@lvs2 ~]# ipvsadm -at 192.168.220.140:80 -r 192.168.220.132 -g
  5. [root@lvs2 ~]# 然后我们可以使用ipvsadm 监控目前LVS的状态
  6. [root@lvs2 ~]# ipvsadm
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

注意:处于standby的lvs1节点也要这样进行设置。 
还有,以上的LVS的设置,和real server上的设置,在重启后都会消失,所以一定要做成脚本哦。

4、验证工作

这样LVS + Keepalived + Nginx方式的配置就做完了。现在我们进行搭建效果的监测:

4-1、验证Master-LVS节点的工作

我们使用两个不同的浏览器,验证Master-LVS节点的工作:

=========浏览器1: 

=========浏览器2: 

看来140这个VIP下的LVS工作是正常的。

4-2、验证Master-LVS节点停止后的效果

下面我们停止Master-LVS1:

  1. [root@lvs2 ~]# service keepalived stop
  • 1
  • 1

在经历了一些访问停顿后,浏览器1显示的效果如下(这就是为什么keepalived最好设置为非抢占模式):

5、后文介绍

好了,到这里负载均衡层所使用的几个标准工具就介绍完了。下一篇文章我们将进行总结,然后进入架构设计:业务层设计方案 的系列文章。在下一个系列文章中,我们将介绍至少两套SOA的实现、至少两套系统间通信使用的消息队列。哦,应我朋友的要求,我会专门写几篇文章,介绍Java中线程的基础知识和进阶知识。

http://blog.csdn.net/yinwenjie/article/details/47211551

架构设计:负载均衡层设计方案(7)——LVS + Keepalived + Nginx安装及配置的更多相关文章

  1. 架构设计:负载均衡层设计方案(2)——Nginx安装

    来源:http://blog.csdn.net/yinwenjie(未经允许严禁用于商业用途!) 目录(?)[-] Nginx重要算法介绍 1一致性Hash算法 2轮询与加权轮询 Nginx的安装 1 ...

  2. 架构设计:负载均衡层设计方案(3)——Nginx进阶

    版权声明:欢迎转载,但是看在我辛勤劳动的份上,请注明来源:http://blog.csdn.net/yinwenjie(未经允许严禁用于商业用途!) 目录(?)[-] Nginx继续进阶 1gzip ...

  3. 架构设计:负载均衡层设计方案(6)——Nginx + Keepalived构建高可用的负载层

    1.概述 前两遍文章中,我们一直在说后文要介绍Nginx + Keepalived的搭建方式.这篇文章开始,我们就来兑现前文的承诺,后续的两篇文章我们将介绍Nginx + Keepalived和 LV ...

  4. LVS + Keepalived + Nginx安装及配置

    1.概述 上篇文章<架构设计:负载均衡层设计方案(6)——Nginx + Keepalived构建高可用的负载层>(http://blog.csdn.net/yinwenjie/artic ...

  5. LVS+Nginx(LVS + Keepalived + Nginx安装及配置)

    (也可以每个nginx都挂在上所有的应用服务器)  nginx大家都在用,估计也很熟悉了,在做负载均衡时很好用,安装简单.配置简单.相关材料也特别多. lvs是国内的章文嵩博士的大作,比nginx被广 ...

  6. 架构设计:负载均衡层设计方案(4)——LVS原理

    之前我们花了两篇文章的篇幅,详细讲解了Nginx的原理.安装和特性组件.请参看<负载均衡层设计方案(2)——Nginx安装>(http://blog.csdn.net/yinwenjie/ ...

  7. 架构设计:负载均衡层设计方案(5)——LVS单节点安装

    1.概述 上篇文章<架构设计:负载均衡层设计方案(4)——LVS原理>(http://blog.csdn.net/yinwenjie/article/details/46845997),我 ...

  8. lvs + keepalived + nginx + tomcat高可用负载反向代理服务器配置(一) 简介

    一. 为什么这样构架 1. 系统高可用性 2. 系统可扩展性 3. 负载均衡能力 LVS+keepalived能很好的实现以上的要求,keepalived提供健康检查,故障转移,提高系统的可用性!采用 ...

  9. 系统架构之负载均衡【F5\nginx\LVS\DNS轮询\】

    在做系统架构规划的时候,负载均衡,HA(高可用性集群,是保证业务连续性的有效解决方案,一般有两个或两个以上的节点,且分为活动节点及备用节点,当活动节点出现故障的时候,由备用节点接管)都是经常需要考虑的 ...

随机推荐

  1. HDU ACM 2121 Ice_cream’s world II (无根最小树形图)

    [解题思路]这题先看了NotOnlySuccess的解题思路,即设置虚根再处理的做法:弄了一个上午,再次有种赶脚的感觉~~如果需要找出为什么需要去比所有权值之和更大的数为新增的虚边的话,一开始我理解仅 ...

  2. mysql系统表加trigger和对特定的库禁用 DDL 语句

    给 mysql 系统表加上 trigger 1 Reply 默认情况下,mysql 是不能给系统表,例如 mysql.user 加上触发器的.会提示 ERROR 1465 (HY000): Trigg ...

  3. delphi 判断调试状态

    DebugHook 该变量在调试状态下值为1,运行模式为0,例如,我们可以使用如下的代码来简单控制: if DebugHook=0 then

  4. 删除Ngnix 日志

    删除Ngnix日志的脚本 #!/bin/bash #初始化 LOGS_PATH=$(pwd)/logs YESTERDAY=$(date -d "yesterday" +%Y-%m ...

  5. ESB 客户端调用 处理类

    esb package com.isoftstone.synchronize.entrance; import java.io.File; import java.text.SimpleDateFor ...

  6. listview的tag

    tag,记录一行数据的唯一标识,小DEMO: lsShow.Items.Add("洗衣机"); lsShow.Items[].Tag = "我不愿让你一个人"; ...

  7. How Tomcat Works(八)

    下面接着分析Context容器,该接口最重要的方法是addWrapper()方法与creatWrapper()方法,添加具体的子容器,这里是Wrapper容器实例 这里要分析的是一个简单的Contex ...

  8. ASP.NET MVC- 解决HTML转码

    在MVC里从Controller发送一段带有HTML的文字到View视图时,MVC是会将这段代码进行转码的. 一.使用MvcHtmlString转HTML转码 如果想不让这段文字进行转码,以HTML的 ...

  9. SQL Server中行列转换

    典型实例 一.行转列 1.建立表格 ifobject_id('tb')isnotnulldroptabletb go createtabletb(姓名varchar(10),课程varchar(10) ...

  10. Openfire开发配置,Openfire源代码配置,OpenFire二次开发配置(eclipse)

    首先去官网把openfire的源码下下来: http://www.igniterealtime.org/downloads/source.jsp 1.下载后放到你的workspace当中,我的woek ...