|
Падает веб-приложение с ошибкой "Задание не найдено"
|
|||
---|---|---|---|
#18+
Здравствуйте! Стоит сервер Windows Server 2008 R2 Enterprise 64 OS 20 GB ozu. На нём веб-сервер IIS. На этом веб-сервере крутится asp.net приложение, которое выгружает из БД данные по запросу и загружает. До текущего месяца всё было нормально, но в этом месяце оно начало падать на определенном наборе данных (одном из самых больших) с ошибкой "Задание не найдено". Это сообщение валится вот из этого класса, из вот этого метода "GetTaskStatus": Код: c# 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. 24. 25. 26. 27. 28. 29. 30. 31. 32. 33. 34. 35. 36. 37. 38. 39. 40. 41. 42. 43. 44. 45. 46. 47. 48. 49. 50. 51. 52. 53. 54. 55. 56. 57. 58. 59. 60. 61. 62. 63. 64. 65. 66. 67. 68. 69. 70. 71. 72. 73. 74. 75. 76. 77. 78. 79. 80. 81. 82. 83. 84. 85. 86. 87. 88. 89. 90. 91. 92. 93. 94. 95. 96. 97. 98. 99. 100. 101. 102. 103. 104. 105. 106. 107. 108. 109. 110. 111. 112. 113. 114. 115. 116. 117. 118. 119. 120. 121. 122. 123. 124. 125. 126. 127. 128. 129. 130. 131. 132. 133. 134. 135. 136. 137. 138. 139. 140. 141. 142. 143. 144. 145. 146. 147. 148. 149. 150. 151. 152. 153. 154. 155. 156. 157. 158. 159. 160. 161. 162. 163. 164. 165. 166. 167. 168. 169. 170. 171. 172. 173. 174. 175. 176. 177. 178. 179. 180. 181. 182. 183. 184. 185. 186. 187. 188. 189. 190. 191. 192. 193. 194. 195. 196. 197. 198. 199. 200. 201. 202. 203. 204. 205. 206. 207. 208. 209. 210. 211. 212.
Прога написана лет 10 назад, исходников нет. taskId из метода GetTaskStatus - это 4-х значный номер, который при каждом запуске увеличивается на единицу. Отдельно получилось декомпилить библиотеку с классом и методом TaskProcessor.Find(taskId), в котором возникает ошибка: Код: c# 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. 24. 25. 26. 27. 28. 29. 30. 31. 32. 33. 34. 35. 36. 37. 38. 39. 40. 41. 42. 43. 44. 45. 46. 47. 48. 49. 50. 51. 52. 53. 54. 55. 56. 57. 58. 59. 60. 61. 62. 63. 64. 65. 66. 67. 68. 69. 70. 71. 72. 73. 74. 75. 76. 77. 78. 79. 80. 81. 82. 83. 84. 85. 86. 87. 88. 89. 90. 91. 92. 93. 94. 95. 96. 97. 98. 99. 100. 101. 102. 103. 104. 105. 106. 107. 108. 109. 110. 111. 112. 113. 114. 115. 116. 117. 118. 119. 120. 121. 122. 123. 124. 125. 126. 127. 128. 129. 130. 131. 132. 133. 134. 135. 136. 137. 138. 139. 140. 141. 142. 143. 144. 145. 146. 147. 148. 149. 150. 151. 152. 153. 154. 155. 156. 157. 158. 159. 160. 161. 162. 163. 164. 165. 166. 167. 168. 169. 170. 171. 172. 173. 174. 175. 176. 177. 178. 179. 180. 181. 182. 183. 184. 185. 186. 187. 188. 189. 190. 191. 192. 193. 194. 195. 196. 197. 198. 199. 200. 201. 202. 203. 204. 205. 206. 207. 208. 209. 210. 211. 212. 213. 214. 215. 216. 217. 218. 219. 220. 221. 222. 223. 224. 225. 226. 227. 228. 229. 230. 231. 232. 233. 234. 235. 236. 237. 238. 239. 240. 241. 242. 243. 244. 245. 246. 247. 248. 249. 250. 251. 252. 253. 254. 255. 256. 257. 258. 259. 260. 261. 262. 263. 264. 265. 266. 267. 268. 269. 270. 271. 272. 273. 274. 275. 276. 277. 278. 279. 280. 281. 282. 283. 284. 285. 286. 287. 288. 289. 290. 291. 292. 293.
Из него удалось вычислить xml-файл, из которого берется данный task - "tasks.xml", который содержит следующие записи: Код: xml 1. 2.
А на дублере сервера с таким же приложением, данный файл выглядит по другому, но ошибка та же: Код: xml 1. 2. 3.
После того как удалил этот xml-файл и запустил сервис, он мне сознал новый файл следующего содержания: Код: xml 1. 2.
но в процессе выполнения там была ещё 1-а стр по типу "<task lastUpdateTime="2020-06-23T13:40:36.5338309+05:00" state="Running" id="7065" name="Формирование файла"/> </tasks>", которая удалилась. Не понимаю, что этот task означает и что с ним может быть не так? ... |
|||
:
Нравится:
Не нравится:
|
|||
25.06.2020, 20:52 |
|
Падает веб-приложение с ошибкой "Задание не найдено"
|
|||
---|---|---|---|
#18+
Vlad__i__mir, У Вас програмулина ищет в файле tasks.xml узлы <task lastUpdateTime="YYYY-MM-DDTHH:MM:SS" state="<STATE_ENUM>" id="<id>" name="taskName"/> Класс TaskProcessor оперирует файлом tasks.xml структура которого является что-то вида Код: xml 1. 2. 3. 4. 5.
Ваше asp.net приложение запускает задачи вызовами метода TaskProcessor.Start Задача представляет из себя вызов внешнего приложения находящегося в подкаталоге Bin вашего приложения в вашем случае это что то типа C:\Program Files (x86)\Integro\InMeta\InMetaApps\Bin\AccountingCardTasks\AccountingCardTasks.exe с некоторыми параметрами. К примеру если в ваш веб-сервис поступит вызов на AcceptCard, то в файлик tasks.xml будет добавлена строка Код: xml 1.
Далее уже вы сможете вызывать метод который будет запрашивать статус выполняемой задачи по его присвоенному идентификатору. Ваша проблема в том что вы вызываете метод запроса статуса когда эта задача уже по факту перестала работать. Удаляются задачи из файла только в том случае если внешнее приложение изменит их статус на "error" или "complete" ИЛИ еще задачи удаляются если они протухли по дате когда идет обращение метода TaskProcessor.Open и файл существует он выпадает в ветку кода которая ищет записи <task/> и если их время жизни более одного дня, то такая задача считается протухшей и она удаляется из файла. Код: sql 1. 2. 3. 4. 5. 6.
... |
|||
:
Нравится:
Не нравится:
|
|||
25.06.2020, 23:58 |
|
Падает веб-приложение с ошибкой "Задание не найдено"
|
|||
---|---|---|---|
#18+
felix_ff, большое вам спасибо! Сейчас стало понятно. А если я запускаю программу и она думает конечно долго - минут 5, но точно не день и больше, то по идее она еще не должна становится "протухшей", а из-за чего тогда он не может её найти? На остальных наборах данных, но они поменьше всё работает ... |
|||
:
Нравится:
Не нравится:
|
|||
26.06.2020, 06:52 |
|
Падает веб-приложение с ошибкой "Задание не найдено"
|
|||
---|---|---|---|
#18+
felix_ff,вот на этой задачи он сыпется, она последней появляется в tasks.xml перед сбоем: Код: xml 1. 2. 3.
... |
|||
:
Нравится:
Не нравится:
|
|||
26.06.2020, 07:29 |
|
Падает веб-приложение с ошибкой "Задание не найдено"
|
|||
---|---|---|---|
#18+
Vlad__i__mir felix_ff,вот на этой задачи он сыпется, она последней появляется в tasks.xml перед сбоем: Код: xml 1. 2. 3.
Нашел и декомпилил класс UnloadAccountingCard. Процесс идет до строки Код: c# 1.
, а дальше выбрасывается исключение, что задача не найдена. При чем судя по всему не одно из исключений данного класса не срабатывает: Код: c# 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. 24. 25. 26. 27. 28. 29. 30. 31. 32. 33. 34. 35. 36. 37. 38. 39. 40. 41. 42. 43. 44. 45. 46. 47. 48. 49. 50. 51. 52. 53. 54. 55. 56. 57. 58. 59. 60. 61. 62. 63. 64. 65. 66. 67. 68. 69. 70. 71. 72. 73. 74. 75. 76. 77. 78. 79. 80. 81. 82. 83. 84. 85. 86. 87. 88. 89. 90. 91. 92. 93. 94. 95. 96. 97. 98. 99. 100. 101. 102. 103. 104. 105. 106. 107. 108. 109. 110. 111. 112. 113. 114. 115. 116. 117. 118. 119. 120. 121. 122. 123. 124. 125. 126. 127. 128. 129. 130. 131. 132. 133. 134. 135. 136. 137. 138. 139. 140. 141. 142. 143. 144. 145. 146. 147. 148. 149. 150. 151. 152. 153. 154. 155. 156. 157. 158. 159. 160. 161. 162. 163. 164. 165. 166. 167. 168. 169. 170. 171. 172. 173. 174. 175. 176. 177. 178. 179. 180. 181. 182. 183. 184. 185. 186. 187. 188. 189. 190. 191. 192. 193. 194. 195. 196. 197. 198. 199. 200. 201. 202. 203. 204. 205. 206. 207. 208. 209. 210. 211. 212. 213. 214. 215. 216. 217. 218. 219. 220. 221. 222. 223. 224. 225. 226. 227. 228. 229. 230. 231. 232. 233. 234. 235. 236. 237. 238. 239. 240. 241. 242. 243. 244. 245. 246. 247. 248. 249. 250. 251. 252. 253. 254. 255. 256. 257. 258. 259. 260. 261. 262. 263. 264. 265. 266. 267. 268. 269. 270. 271. 272. 273. 274. 275. 276. 277. 278. 279. 280. 281. 282. 283. 284. 285. 286. 287. 288. 289. 290. 291. 292. 293. 294. 295. 296. 297. 298. 299. 300. 301. 302. 303. 304. 305. 306. 307. 308. 309. 310. 311. 312. 313. 314. 315. 316. 317. 318. 319. 320. 321. 322. 323. 324. 325. 326.
... |
|||
:
Нравится:
Не нравится:
|
|||
26.06.2020, 07:46 |
|
Падает веб-приложение с ошибкой "Задание не найдено"
|
|||
---|---|---|---|
#18+
Vlad__i__mir, Вам надо отдебажить запуск приложения AccountingCardTasks.exe когда у вас запускается метод веб-сервиса UnloadCard он как раз запускает эту задачу: Код: sql 1.
раз она присутствует в файле, то TaskProcessor отработал нормально и стартовал процесс типа: AccountingCardTasks.exe Action=unload AppId={какой то идентификатор} UserAccount={какой то пользователь} ComplexId={что то еще } OutputDir={путь выгрузки к картам} после этого через какое то время у вас видимо проиходит вызов запроса статуса задачи, есть подозрение что к этому моменту какой то из процессов успевает очистить ту задачу, или запрос статуса приходит по другому id. Вы можете менять сам web-сервис? На сколько я вижу у вас asmx служба без использования Code behind, но по сути раз у вас есть ее исходник вам ничего не должно менять встроить некое логирование и скомпилить библиотеку. Вам нужно понимать какой параметр передается в метод GetTaskStatus(string taskId ). У меня есть подозрение что запрашивается статус какой то другой задачи. ... |
|||
:
Нравится:
Не нравится:
|
|||
26.06.2020, 11:58 |
|
Падает веб-приложение с ошибкой "Задание не найдено"
|
|||
---|---|---|---|
#18+
felix_ff, Прога писалась лет 10 назад компанией, исходников нет - это я через dotPeek декомпилю её по кусочкам, а весь проект декомпилить и запустить целиком не получается Сделал так: Код: c# 1. 2. 3.
Вывело: taskId=5 Перед запуском в xml было: Код: xml 1. 2.
стало: Код: xml 1. 2.
... |
|||
:
Нравится:
Не нравится:
|
|||
26.06.2020, 12:32 |
|
Падает веб-приложение с ошибкой "Задание не найдено"
|
|||
---|---|---|---|
#18+
felix_ff, Vlad__i__mir, *во время выполнения, а не "стало": Код: xml 1. 2. 3.
а после стало: Код: c# 1. 2.
Такое ощущение, что он сперва удаляет строку с номером текущей задачи, а потом уже не может её найти ... |
|||
:
Нравится:
Не нравится:
|
|||
26.06.2020, 12:46 |
|
Падает веб-приложение с ошибкой "Задание не найдено"
|
|||
---|---|---|---|
#18+
Vlad__i__mir, это фигня какая то. я бы на вашем месте разобрался кто удаляет строку, можно к примеру ProcessMonitor натравить на доступ к файлу, там явно будет уменьшение размера файла. нужно понимать какой процесс удаляет строку, по временным меткам сможете отследить когда будет добавлена строка а когда удалена и какой процесс ее убирает. Еще как вариант натравить дебагер на w3wp.exe под которым крутится рабочий процесс iis Ну или может кто получше решение посоветует + в вашем вебсервисе в случае исключений в веб-сервисе идет проброс наверх, скорее всего где то ведется более детальный лог всего сервера приложений ... |
|||
:
Нравится:
Не нравится:
|
|||
26.06.2020, 15:15 |
|
Падает веб-приложение с ошибкой "Задание не найдено"
|
|||
---|---|---|---|
#18+
кстати может достаточно поздно предлагаю: а вы на поддержку вашей "интерго" не хотите обратится? может вам быстрее там помогут чем пытаться рабозраться в легаси коде? ... |
|||
:
Нравится:
Не нравится:
|
|||
26.06.2020, 15:42 |
|
Падает веб-приложение с ошибкой "Задание не найдено"
|
|||
---|---|---|---|
#18+
felix_ff кстати может достаточно поздно предлагаю: а вы на поддержку вашей "интерго" не хотите обратится? может вам быстрее там помогут чем пытаться рабозраться в легаси коде? Спасибо вам за консультацию, я стал лучше понимать проблему! Да, я им задал вопрос, и вот жду, может ответят. Программа то у нас давно уже не на поддержки ... |
|||
:
Нравится:
Не нравится:
|
|||
26.06.2020, 21:43 |
|
|
start [/forum/search_topic.php?author=maximusend&author_mode=last_topics&do_search=1]: |
0ms |
get settings: |
10ms |
get forum list: |
15ms |
get settings: |
12ms |
get forum list: |
13ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
55ms |
get topic data: |
11ms |
get forum data: |
3ms |
get page messages: |
54ms |
get tp. blocked users: |
2ms |
others: | 9841ms |
total: | 10022ms |
0 / 0 |