2017-01-10 1 views
1

이것은 나에게 정말로 골칫거리입니다. 나는 장고와 파이썬 2.7에서 실행되는 전보 봇을 가지고있다. 개발하는 동안 나는 django sslserver를 사용했고 모든 것이 잘 동작했다. 오늘은 nginx에서 gunicorn을 사용하여 배포했으며 코드는 내 localhost에서와 매우 다릅니다. 나는 이미 사용자를 확보하기 시작 했으므로 가능한 모든 것을 시도했지만 모두 쓸모가 없습니다. 대부분의 파이썬 객체는 요청이있을 때마다 상태를 잃어 버리고 이것이 문제의 원인이 될 수 있습니다. 내가 사용하는 라이브러리에는 전보 사용자와의 대화를 처리하는 클래스가 있으며 대화 상태는 클래스 인스턴스에 저장됩니다. 때로는 새로운 요청이 오면 그 값은 이미 손실됩니다. 아무도 이것을 직면 했습니까? 문제를 빨리 해결할 수있는 방법이 있습니까? 중요한 상황에 처해 있으며 빠른 해결책이 필요합니다.nginx에서 요청할 때마다 파이썬 객체가 상태를 잃습니다.

+4

gunicorn은 프리 포크 작업자 모델을 사용합니다. Prefork. ** 당신은 독립적 인 프로세스 **를 가지고 있음을 의미합니다. 독립적 인, 그들은 자신의 상태를 가지고 있으며, 서로 기억을 공유하지 않습니다. 중앙 저장소 (redis, & c)와 통신 할 수있는 시스템을 구축하지 않은 경우 드로잉 보드로 돌아 가야합니다. –

+0

@ Charles Duffy, 데이터베이스가 있지만 사용중인 라이브러리는 상태를 저장하는 것 같습니다. 또한, 나는 gunicorn에 대해이 사실을 모릅니다. – Ken

+1

잠시 동안 작업자 수를 1로 줄일 수 있습니다. 성능이 저하되지만 전혀 작동하지 않는 서비스보다 나은 것입니다. –

답변

2

Gunicorn은 프리 포킹 작업자 모델을 가지고 있습니다. 즉,로드의 하위 집합을 처리하는 여러 가지 독립된 하위 프로세스를 시작합니다.

서비스 제공과 관련된 모든 스레드에서 내부 응용 프로그램 상태가 일관성을 유지하려면 모든 스레드가 동일한 프로세스 내에 있는지 확인하기 위해 작업자 수를 1로 낮추어야합니다. 물론


, 이것은 임시 변통 - 당신은 응용 프로그램을 백업 여러 대의 서버를 생산 부하를 실행하거나 가지고 솔루션을 확장 할 수 있도록하려면, 당신은 시스템을 수정하는 것으로 할 것 프로세스 내에서 사용 가능한 컨텐트에 의존하기보다 관련 상태를 공유 된 저장소에 유지하는 것.

관련 문제