>데이터 베이스 >MySQL 튜토리얼 >Python에서 MySQL 연결 시간 초과를 방지하는 방법은 무엇입니까?

Python에서 MySQL 연결 시간 초과를 방지하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-08 12:20:16782검색

How to Avoid MySQL Connection Timeouts in Python?

Python에 대한 MySQL 연결 시간 초과를 구성하는 방법

Python을 통해 MySQL 데이터베이스에 연결할 때 직면하게 되는 일반적인 문제는 기본 연결 시간 초과입니다. 이로 인해 특히 장기 실행 작업의 경우 오류가 발생할 수 있습니다. 이 기사에서는 기본 시간 초과 설정을 수정하고 이러한 문제를 완화하는 방법을 살펴보겠습니다.

기본 시간 초과 설정 결정

MySQL의 기본 시간 초과 설정은 다를 수 있습니다. 서버 구성에 따라 다릅니다. 현재 값을 확인하려면 MySQL 명령줄 클라이언트(예: mysql)를 사용하여 데이터베이스에 연결하세요. 다음 명령을 실행하세요:

SHOW VARIABLES LIKE '%timeout%';

이렇게 하면 시간 초과 설정이 표시됩니다. 포함:

  • connect_timeout
  • delayed_insert_timeout
  • innodb_lock_wait_timeout
  • innodb_rollback_on_timeout
  • interacti ve_timeout
  • lock_wait_timeout
  • net_read_timeout
  • net_writ e_timeout
  • slave_net_timeout
  • wait_timeout

변경 중 기본 시간 초과

시간 초과 설정을 수정하려면 Python 클라이언트(_mysql)를 사용하여 데이터베이스에 연결합니다. 다음 쿼리를 실행합니다.

con.query('SET GLOBAL connect_timeout=28800')
con.query('SET GLOBAL interactive_timeout=28800')
con.query('SET GLOBAL wait_timeout=28800')

이 설정은 다음을 제어합니다.

  • connect_timeout: 연결 설정에 허용되는 시간(여기서는 8시간)
  • interactive_timeout: 최대 비활성 대화형 연결 기간(8시간)
  • wait_timeout: 모든 연결의 최대 비활성 기간 (8시간)

권장

10시간 실행 시간의 경우 더 높은 시간 초과 값(예: 32400초 또는 9시간)을 설정하는 것이 좋습니다. ). 이는 초과된 시간 초과로 인한 연결 중단을 방지하고 Python 프로그램의 중단 없는 작동을 보장합니다.

위 내용은 Python에서 MySQL 연결 시간 초과를 방지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.