동접자가 많아지고 백그라운드 잡이 많아지면 점점 서버가 느려지고 백그라운드 잡이 실패하는 경우도 생깁니다.
Redis Server > Sidekiq > Background Job (내부에서 Mysql 쿼리문을 던짐) > 반복
인 경우, 몇백개의 작업이 동시에 실행되면 Mysql database에 동시 접속 가능한 Pool의 갯수가 작을 경우 default로 설정된 타임아웃(5초)로 인해 Background Job이 실패를 하는 경우가 있습니다!
첫번째로는 일단 Mysql의 pool을 늘려주어야 합니다. Mysql에 쿼리를 보내면 처리하는 종업원의 수를 늘려봅니다.
실서버의 /shared/config/database.yml을 만져줍시다.
production:
adapter: mysql2
...: ...
pool: 50
종업원의 숫자를 50명으로 늘려줍니다.
혹시나 데이터베이스에서 사용한 버퍼 메모리가 작을 수 있으니 체크를 해봅니다.
mysql -u root -p 로 접속 후,
mysql> SHOW STATUS LIKE '%innodb_buffer_pool%';
bytes_data 를 보시면 현재 34메가를 사용중이네요. 혹시나 가용 버퍼 메모리를 바꾸고 싶다면,
vi etc/mysql/my.cnf에 해당 세팅을 추가한 후 리스타트 하시면 됩니다.
[mysqld]
…
innodb_buffer_pool_size = 64M
자 이제 Pool은 늘렸으니 Sidekiq에서 일을 하는 종업원 수를 늘릴 차례입니다.
initializer/sidekiq.rb 를 들어갑니다 (없으시면 생성하시면 됩니다.)
Sidekiq.configure_server do |config|
ActiveRecord::Base.connection.disconnect!
ActiveRecord::Base.configurations['production']['pool'] = 50
#ActiveRecord::Base.configurations['staging']['pool'] = 50
ActiveRecord::Base.establish_connection
end
'옛글 > Ruby on the Rails' 카테고리의 다른 글
Rails 구글 크롬 노티피케이션(푸쉬) FCM(Firebase)로 붙이기 (0) | 2017.10.13 |
---|---|
[Ruby on rails] ElasticSearch 를 붙여보자 (0) | 2017.04.14 |
[Ruby on rails] 서버 속도 (+MYSQL)를 개선해보자! (0) | 2017.04.12 |
RVM to Rbenv (0) | 2016.01.08 |
Heroku deploy 시 Push rejected, no Cedar-supported app detected (0) | 2015.01.05 |