+7 (495) 229-0436   shopadmin@itshop.ru 119334, г. Москва, ул. Бардина, д. 4, корп. 3
 
 
Вход
 
 
Каталог
 
 
Подписка на новости
Новости ITShop
Windows 7 и Office: Новости и советы
Обучение и сертификация Microsoft
Вопросы и ответы по MSSQLServer
Delphi - проблемы и решения
Adobe Photoshop: алхимия дизайна
 
Ваш отзыв
Оцените качество магазина ITShop.ru на Яндекс.Маркете. Если вам нравится наш магазин - скажите об этом Google!
 
 
Способы оплаты
 
Курс расчета
 
 1 у.е. = 91.78 руб.
 
 Цены показывать:
 
 
 
 
  
Новости, статьи, акции
 

Проблемы в использовании FTP-клиента на базе UTL_TCP

01.12.2009 14:43

Сегодня хотелось бы рассказать немного про проблемы в использовании пакета ftp с www.oracle-base.com. Я знаю многих, кто его использует, сам не являюсь исключением. Что сказать, удобно, прям с базы собрал данные, запихнул их в нужные таблицы и не нужно заморачиваться с отдельным внешним сборщиком. Но в четверг мы наткнулись на проблему, решили которую только сегодня (итого 4 рабочих дня и 1 выходной). Итак...

Кому не интересна история, а нужен конкретный совет, топают в Решение.

С четверга начали появляться сессии, активные по многу часов, вернее пока не грохнешь, а грохнуть через ALTER SYSTEM KILL SESSION не удавалось, так и оставались висеть со статусом KILLED. В пятницу пользователи начали звонить и говорить, что при попытке выполнить функцию "Бла-бла-бла" получают зависшее приложение. Ну делать нечего, надо решать быстро, благо пользователей немного, сделал STARTUP FORCE и вроде все заработало. Но это костыль, который пользовать часто нельзя, а лучше вообще не пользовать.
Небольшое лирическое отступление... Система построена для выполнения данной функции примерно так: сервер приложений (IIS) <-> основной инстанс <-> вспомогательный <-> масса ftp-серверов. Вспомогательный инстанс заведен на сервере, расположенном в двух сетках и используется исключительно для передачи данных между сетками (так уж была придумана секьюрность еще до моего прихода). На вспомогательном инстансе используется указанный импровизированный ftp-клиент c Oracle-Base. Написана пара функций, которые возвращают содержимое необходимых файлов. Доступ к этим функциям выполняется через DB Link с основного инстанса.
Так вот, работало оно работало, работало оно работало, и тут бац! и перестало работать. Бывает. Начали искать проблему у себя, где может быть зацикливание, deadlocks и т.п. (в логах то было ORA-02080). В общем пришел к тому (откопал на SQL.RU), что эта ошибка выдается нам, если очень долго читаются/ожидаются данные через линку. Полезли вручную на FTP, оказалось реально проблема с ftp-сервером. Однако было непонятно, почему сессия вешается в статусе ACTIVE, а не отваливается по таймауту. Ограничивали даже время жизни соединения в приложении, но все равно сессии на сервере оставались даже после того как приложение завершало свою работу по таймауту.
Тут как назло починили FTP... Воспроизвести ошибку нереально...
Тут полез по до сих пор непонятной мне причине в пакет ftp, в функцию login и обнаружил, что при создании соединения в UTL_TCP.OPEN_CONNECTION не передается таймаут. По умолчанию он установлен в NULL, что означает, что он бесконечен и ошибка по таймауту не вывалится никогда.

Решение

Вот решил я подправить этот пакет для возможности установки таймаута, чего и вам советую.
В спецификации пакета FTP делаем следующие изменения:

FUNCTION login (p_host    IN  VARCHAR2,
p_port IN VARCHAR2,
p_user IN VARCHAR2,
p_pass IN VARCHAR2,
p_timeout IN NUMBER := NULL)
RETURN UTL_TCP.connection;
В теле пакета делаем так:
FUNCTION login (p_host    IN  VARCHAR2,
p_port IN VARCHAR2,
p_user IN VARCHAR2,
p_pass IN VARCHAR2,
p_timeout IN NUMBER := NULL)
RETURN UTL_TCP.connection IS
-- --------------------------------------------------------------------------
l_conn UTL_TCP.connection;
BEGIN
g_reply.delete;

l_conn := UTL_TCP.open_connection(p_host, p_port, tx_timeout => p_timeout);
get_reply (l_conn);
send_command(l_conn, 'USER ' // p_user);
send_command(l_conn, 'PASS ' // p_pass);
RETURN l_conn;
END;

Соответственно, в своих приложениях, где нужно все же установить таймаут, вызываете ftp.login с указанием p_timeout => 60 (для таймаута = 1 минуте).
 

Ссылки по теме

  
Помощь
Задать вопрос
 программы
 обучение
 экзамены
 компьютеры
Бесплатный звонок
ICQ-консультанты
Skype-консультанты

Общая справка
Как оформить заказ
Тарифы доставки
Способы оплаты
Прайс-лист
Карта сайта
 
Бестселлеры
Курсы обучения "Atlassian JIRA - система управления проектами и задачами на предприятии"
Microsoft Windows 10 Профессиональная 32-bit/64-bit. Все языки. Электронный ключ
Microsoft Office для Дома и Учебы 2019. Все языки. Электронный ключ
Курс "Oracle. Программирование на SQL и PL/SQL"
Курс "Основы TOGAF® 9"
Microsoft Office 365 Персональный 32-bit/x64. 1 ПК/MAC + 1 Планшет + 1 Телефон. Все языки. Подписка на 1 год. Электронный ключ
Курс "Нотация BPMN 2.0. Ее использование для моделирования бизнес-процессов и их регламентации"
 

О нас
Интернет-магазин ITShop.ru предлагает широкий спектр услуг информационных технологий и ПО.

На протяжении многих лет интернет-магазин предлагает товары и услуги, ориентированные на бизнес-пользователей и специалистов по информационным технологиям.

Хорошие отзывы постоянных клиентов и высокий уровень специалистов позволяет получить наивысший результат при совместной работе.

В нашем магазине вы можете приобрести лицензионное ПО выбрав необходимое из широкого спектра и ассортимента по самым доступным ценам. Наши менеджеры любезно помогут определиться с выбором ПО, которое необходимо именно вам. Также мы проводим учебные курсы. Мы приглашаем к сотрудничеству учебные центры, организаторов семинаров и бизнес-тренингов, преподавателей. Сфера сотрудничества - продвижение бизнес-тренингов и курсов обучения по информационным технологиям.



 

О нас

 
Главная
Каталог
Новинки
Акции
Вакансии
 

Помощь

 
Общая справка
Как оформить заказ
Тарифы доставки
Способы оплаты
Прайс-лист
Карта сайта
 

Способы оплаты

 

Проекты Interface Ltd.

 
Interface.ru   ITShop.ru   Interface.ru/training   Olap.ru   ITnews.ru  
 

119334, г. Москва, ул. Бардина, д. 4, корп. 3
+7 (495) 229-0436   shopadmin@itshop.ru
Проверить аттестат
© ООО "Interface Ltd."
Продаем программное обеспечение с 1990 года