1.1 Synopsis

In this part, we will explain how to create a load-balancer withnginxfor a lot of OpenERPservers.The

load-balancing

and the

multi-process

mode of OpenERPonly work with gunicorn.And in this case, the cron are not launched by the system.

1.2 Nginx

Nginx is a free, open-source, high-performance HTTP server and reverse proxyYou can copy/paste the code in

/etc/nginx/sites-enabled/

with a filenameYou will find the documentation about the upstream keyword at

http://wiki.nginx.org/HttpUpstreamModule

 

upstream
openerp_servers{
server
openerp-server1.back.local max_fails=3 fail_timeout=30s;
server
openerp-server2.back.local max_fails=3 fail_timeout=30s;
server
openerp-server3.back.local max_fails=3 fail_timeout=30s;}
serfver
{
listen
80;
server_name
openerp.example.com;
rewrite
^ https://$server_name$request_uri?permanent;}
server
{
listen
443;
server_name
openerp.example.com;
access_log
/var/log/nginx/openerp.example.com-access.log;
error_log
/var/log/nginx/openerp.example.com-error.log debug;
ssl
on;
ssl_certificate
/etc/nginx/ssl/server.crt;
ssl_certificate_key
/etc/nginx/ssl/server.key;
ssl_session_timeout
5m;
ssl_protocols
SSLv3 TLSv1;
ssl_ciphers
ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv3:+EXP;
ssl_prefer_server_ciphers
on;
location
/{
proxy_pass
http://openerp_servers;
proxy_set_header
Host$http_host;
proxy_set_header
X-Real-IP$remote_addr;
proxy_set_header
X-Forwarded-For$proxy_add_x_forwarded_for;}}

1.3 Gunicorn

Gunicornis a Python WSGI HTTP Server for UNIX.

We will use it for the multi-process mode of OpenERP.On the OpenERP servers, just install gunicorn via apt-get

# apt-get install python-gunicorn

1.4 OpenERP

You should configure OpenERP with the gunicorn mode.In the directory of the server, you can execute gunicorn with the following command

cd/home/openerp/servergunicorn openerp:wsgi.proxied.application -c gunicorn.conf.py

2.1 PostgreSQL

2.1.1 Synopsis

PostgreSQLis a free and open source database server.In this documentation, we will use PostgreSQL 9.x because this is the first release with theStreaming Replication.In PostgreSQL, there are two kind of replication.•

Warm Standby

It’s a simple replication without any access.•

Hot Standby

, in this mode, you can connect to the database but only in read access.We will use the

Hot Standby

mode for the Streaming Replication.In this tutorial, we suppose that you use an unix account, named

openerp

.Firstly, we have to configure two PostgreSQL servers, the master and the slave.

2.1.2 Streaming Replication

Here is the directory structure for the tutorial

root@vm:/# tree homehome|-> openerp|-> postgresql|-> master|-> standbymkdir /home/openerp/postgresql

Master

Via this command we initialize a new PostgreSQL cluster.

cd/home/openerp/postgresql/usr/lib/postgresql/9.1/bin/initdb -D master

The

wal_level

parameter specifies the

hot_standby

mode and the

max_wal_senders

is the number of slaveservers. In this case, the value is one.

cat >> master/postgresql.conf<< _EOF_ > include ’replication.conf’> _EOF_ cat >> master/replication.conf<< _EOF_ > wal_level = ’hot_standby’> max_wal_senders = 1> archive_mode = on> #archive_command = ’cp %p /home/stephane/postgresql/test/archives_xlog/%f’> _EOF_

We start the new PostgreSQL cluster

/usr/lib/postgresql/9.1/bin/pg_ctl -D master start

Authentication

We will use the replication via the network, in this case, we have to configure the PostgreSQL server to use a dedicateduser for the replication. In our case, this is the openerp user. It’s a normal postgresql user, don’t forget to set all therights for this user and a password.

createuser openerppsql -d postgres -c"ALTER USER openerp PASSWORD ’secret’;"

Note:

Here is a part of the content of the

master/pg_hba.conf

file

# The replication database is a virtual database used by the replication processhost replication openerp 127.0.0.1/32 md5

# Don’t forget to restart the master server before the slave because without that, the slave can’t b

/usr/lib/postgresql/9.1/bin/pg_ctl -D master restart

Slave

Tocreateabackupofthemasterfortheslave, youcanusethe

pg_basebackup

commandprovidedwithPostgreSQL9.1.

cd/home/openerp/postgresql/usr/lib/postgresql/9.1/bin/pg_ctl/pg_basebackup -D standby -v -P -Fp -l backup -h 127.0.0.1 -U open

We configure the standby server to listen to the port 5433 (because we are on the same physical server). If the standbyserver is another server, don’t forget to use 5432.

cat > standby/replication.conf<< _EOF_ > port = 5433> hot_standby = on> _EOF_

The

primary_conninfo

is used by the Streaming Replication, the parameter have the hostname of the master withthe port and the pair user/password.

 

cat > standby/recovery.conf<< _EOF_ > standby_mode = ’on’> primary_conninfo = ’host=127.0.0.1 port=5432 user=openerp password=secret’> trigger_file = ’/tmp/standby’> _EOF_

In this config file, the trigger_file key will be used by the server, if there is a touch on this file, the standby server willautomatically pass in the master mode with the read/write accesses.

2.2 PG-Pool II

For the load-balancing and the failover features, we will use PgPool2.

2.2.1 Installation

# apt-get install pgpool2# apt-get install postgresql-9.1-pgpool2

2.2.2 Configuration

Here is the basic configuration for the load-balancing and the failover.The

failover_command

is important because if pgpool can’t make a connection to the master, it will

touch/tmp/standby

file and this file will be triggered by the standby server.If you want to use this feature with a remote standby server, you can use

ssh

to touch a file on a remote server. Butdon’t forget to change the config file of the standby server and set the right value for the

trigger_file

parameter.

cat >> /etc/pgpool2/pgpool.conf << _EOF_ > port = 5434> load_balance_mode = on> backend_hostname0 = ’localhost’> backend_port0=5432> backend_weight0=1> backend_flag0 = ’ALLOW_TO_FAILOVER’> backend_hostname1 = ’localhost’> backend_port1=5433> backend_weight0=1> backend_flag1 = ’ALLOW_TO_FAILOVER’> failover_command = ’touch /tmp/standby’> _EOF_

CHAPTER ONE LOAD-BALANCING的更多相关文章

  1. NGINX Load Balancing – TCP and UDP Load Balancer

    This chapter describes how to use NGINX Plus and open source NGINX to proxy and load balance TCP and ...

  2. NGINX Load Balancing - HTTP Load Balancer

    This chapter describes how to use NGINX and NGINX Plus as a load balancer. Overview Load balancing a ...

  3. 【架构】How To Use HAProxy to Set Up MySQL Load Balancing

    How To Use HAProxy to Set Up MySQL Load Balancing Dec  2, 2013 MySQL, Scaling, Server Optimization U ...

  4. CF# Educational Codeforces Round 3 C. Load Balancing

    C. Load Balancing time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...

  5. Codeforces Educational Codeforces Round 3 C. Load Balancing 贪心

    C. Load Balancing 题目连接: http://www.codeforces.com/contest/609/problem/C Description In the school co ...

  6. UVA 12904 Load Balancing 暴力

    Load Balancing Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudge/contest/vi ...

  7. Load Balancing 折半枚举大法好啊

    Load Balancing 给出每个学生的学分.   将学生按学分分成四组,使得sigma (sumi-n/4)最小.         算法:   折半枚举 #include <iostrea ...

  8. [zz] pgpool-II load balancing from FAQ

    It seems my pgpool-II does not do load balancing. Why? First of all, pgpool-II' load balancing is &q ...

  9. How Network Load Balancing Technology Works--reference

    http://technet.microsoft.com/en-us/library/cc756878(v=ws.10).aspx In this section Network Load Balan ...

  10. Network Load Balancing Technical Overview--reference

    http://technet.microsoft.com/en-us/library/bb742455.aspx Abstract Network Load Balancing, a clusteri ...

随机推荐

  1. 使用bottle进行web开发(4):HTTPError

    from bottle import error @error(404) def error404(error): return 'Nothing here, sorry' 上述代码,是对404的定义 ...

  2. ubuntu下中文输入法安装

    个人认为ubantu下fcitx比sogo好用 安装fcitx首先到ubantu软件中心下载fcitx两个软件,一个是配置软件,一个是输入法软件 到system setting中language su ...

  3. AC日记——codeforces Ancient Berland Circus 1c

    1C - Ancient Berland Circus 思路: 求出三角形外接圆: 然后找出三角形三条边在小数意义下的最大公约数; 然后n=pi*2/fgcd; 求出面积即可: 代码: #includ ...

  4. IBM-Club IntelliJ IDEA 开发环境的安装

    各位小伙伴初次使用IDE,可能还是有许多疑惑,因此这篇博客阿鲁给大家分享一下,自己平时是如何安装IntelliJ IDEA的 1.原料:安装包,直接百度搜索进入官网下载 记住是Ultimate版本呦, ...

  5. Robot Framework与Web界面自动化测试:简单例子

    假设环境已经搭建好了.这里用RIDE( Robot Framework Test Data Editor)工具来编写用例.下面我们对Robot Framework简称rf. 我们先考虑下一个最基本的登 ...

  6. bzoj4543[POI2014]Hotel

    题目链接 bzoj4543 [POI2014]Hotel 题解 这不是裸地点分嘛 ,我真傻,真的 n^2 这不是是sb题,~滑稽 ~ 枚举点转换为无根树,暴力子树中点的深度 计数转移 令a b c d ...

  7. luogu P1194 买礼物

    题目描述 又到了一年一度的明明生日了,明明想要买B样东西,巧的是,这B样东西价格都是A元. 但是,商店老板说最近有促销活动,也就是: 如果你买了第I样东西,再买第J样,那么就可以只花K[I,J]元,更 ...

  8. 【数论】【暴力】bzoj4052 [Cerc2013]Magical GCD

    考虑向一个集合里添加一个数,它们的gcd要么不变,要么变成原gcd的一个约数.因此不同的gcd只有log个. 所以对于每个位置,维护一个表,存储从这个位置向前所有的不同的gcd及其初始位置,然后暴力更 ...

  9. Java概述--Java开发实战经典

    1)Java有三个发展方向,分别是Java SE,Java EE,Java ME.以下简要介绍. a.Java SE,Java Standard Edition(java标准版),包含了构成java语 ...

  10. ListView控件(上)数据适配器:ListView绑定监听是SetOnItemClickListener

    (一) 1.效果图: 2.MainActivity.java package com.example.app5; import android.support.v7.app.AppCompatActi ...