Freeswitch заблокирован - PullRequest
       12

Freeswitch заблокирован

0 голосов
/ 04 декабря 2018

Программное обеспечение FreeSwitch работает хорошо в течение нескольких дней (~ 3 - 5 дней), затем принимаются новые входящие запросы, так как FreeSwitch заблокирован !!Текущие вызовы продолжают сеанс, кажется, что их вызовы не выполняются, но новые вызовы не принимаются.Я получил снимок FreeSwitch и проанализировал его в GDB.

У меня есть 601 терад, и большинство из них ждут

Thread 0x7f16bc55f700 (LWP 28544) pthread_cond_wait@@GLIBC_2.3.2 () at ../nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_wait.S:185

Когда я применяю "thread apply all bt" в gdb, я вижу большинствоиз потоков пытаются поместить события в очередь (switch_queue_push)

Thread 600 (Thread 0x7f16bc55f700 (LWP 28544)):
#0 pthread_cond_wait@@GLIBC_2.3.2 () at ../nptl/sysdeps/unix/sysv/linux/x86_64/pthread_cond_wait.S:185
#1  0x00007f180cf9b87d in apr_thread_cond_wait (cond=<optimized out>, mutex=<optimized out>) at locks/unix/thread_cond.c:68
#2  0x00007f180cf92dd0 in apr_queue_push (queue=queue@entry=0x7f180db157a8, data=data@entry=0x7f16d3d5ec20) at misc/apr_queue.c:166
#3  0x00007f180cc958fb in switch_queue_push (queue=0x7f180db157a8, data=data@entry=0x7f16d3d5ec20) at src/switch_apr.c:1134
#4  0x00007f180cd17850 in switch_event_queue_dispatch_event (eventp=0x7f16bc55ec48) at src/switch_event.c:384
#5  switch_event_fire_detailed (file=file@entry=0x7f180cfb07ea "src/switch_channel.c", func=func@entry=0x7f180cfb2ba0 <__func__.18348> "switch_channel_perform_set_running_state", line=line@entry=2260, event=event@entry=0x7f16bc55ec48, user_data=user_data@entry=0x0) at src/switch_event.c:1986
#6  0x00007f180cc9f118 in switch_channel_perform_set_running_state (channel=0x7f17e3e7de00, state=CS_NEW, file=0x7f180cfbc590 "src/switch_core_state_machine.c", func=<optimized out>, line=543) at src/switch_channel.c:2260
#7  0x00007f180ccc87d0 in switch_core_session_run (session=0x7f17e3e7fd28) at src/switch_core_state_machine.c:543
#8  0x00007f180ccc36de in switch_core_session_thread (thread=<optimized out>, obj=0x7f17e3e7fd28) at src/switch_core_session.c:1629
#9  0x00007f180ccbf47d in switch_core_session_thread_pool_worker (thread=0x7f17e3e9abb0, obj=0x80) at src/switch_core_session.c:1692
#10 0x00007f180cfa1910 in dummy_worker (opaque=0x7f17e3e9abb0) at threadproc/unix/thread.c:151
#11 0x00007f180c1e0064 in start_thread (arg=0x7f16bc55f700) at pthread_create.c:309
#12 0x00007f180b8b862d in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:111

Почему я собираюсь получить это состояние?Любые мысли, советы, хитрости будут высоко ценится.С уважением,

1 Ответ

0 голосов
/ 06 декабря 2018

Я глубоко исследовал и нашел свое решение,

Вы должны понять " Механизм обработки событий " Freeswitch, чтобы решить эту проблему.Поскольку существует много потоков производителей, которые генерируют и помещают свое событие в эту очередь, однако в этом механизме существует только один потребительский поток.Поток-потребитель, который является известным обработчиком события, доставляет событие всем слушателям, таким как модули, которые прослушивают соответствующее событие.

Один или несколько из этих слушателей могут задержать (через блокировку) этот потребительский поток, и очередь событий может стать заполненной.Когда очередь событий заполнится, ваш переключатель платежей будет заблокирован.

Существует три решения для решения этой проблемы:

1: По умолчаниюКонфигурация, механизм обработчика событий использует очередь событий.Но вы можете использовать потоковое решение для этого с изменением значения " events-use-dispatch = false " в файле " post_load_switch.conf ".

2: Увеличение числа пользовательских потоков, поскольку отдельный потребительский поток не является хорошим решением для сервера с большой нагрузкой и может быть использован с " initial-event-threads = X " в " post_load_switch.conf"файл, где X представляет начальный счетчик потоков.

3: В вашем модуле вы также можете использовать механизм обработки событий.Когда вы получаете событие из ядра Freeswitch, создайте новый поток и назначьте его в ваш недавно созданный поток, чтобы не ожидать пользовательский поток Freeswitch.

...