|
|
|
c# 4.0. Многопоточность и блокировки
|
|||
|---|---|---|---|
|
#18+
Testor1, Есть еще один вариант. Создать не двумерный массив DataRow, а создать к слову 10 переменных типа DataTable. Каждый блок данных загружать в отдельную переменную (DataTable), и в ассинхронном режиме записывать данные на сервер из "загруженной" таблицы и так по кругу :) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.01.2012, 00:53 |
|
||
|
c# 4.0. Многопоточность и блокировки
|
|||
|---|---|---|---|
|
#18+
Testor1, имхо 700 байт слишком мало, чтобы создавать отдельную тачку. Я бы давал порциями по 1000 строк на тачку Попробовать не добавлять в datatable а пусть каждая таска накапливает в список структур результат разбора. И возвращает его через result вставку в базу производить в отдельной нити еще вопрос - какое соотношение времени на 10000 строчках чтение/разбор/вставка? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 25.01.2012, 06:51 |
|
||
|
c# 4.0. Многопоточность и блокировки
|
|||
|---|---|---|---|
|
#18+
странное место, тачку -> таску ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 25.01.2012, 06:52 |
|
||
|
c# 4.0. Многопоточность и блокировки
|
|||
|---|---|---|---|
|
#18+
странное место, Можешь создать код ? Не совсем понял твою идею. Еще учти - что "лишние" операция присваивания - это дополнительные операции с памятью и менеджером памяти. все это замедляет работу. Я достал perfomance анализатор. по его результатм - 60% уходит на запись в базу. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 27.01.2012, 21:49 |
|
||
|
c# 4.0. Многопоточность и блокировки
|
|||
|---|---|---|---|
|
#18+
Testor1странное место, Можешь создать код ? Не совсем понял твою идею. Еще учти - что "лишние" операция присваивания - это дополнительные операции с памятью и менеджером памяти. все это замедляет работу. Я достал perfomance анализатор. по его результатм - 60% уходит на запись в базу. Давай на простом примере попробуем твою идею? Создай проект пусть в цикле передается одна и та же строка "1|22|333|4444|{A:one:B}{C:two:D}|666666" в таблицу в отдельные столбцы должны быть загружены 22,4444,A,B,C,D Кол-во строк 80 000 000 - то есть цикл на это число ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 28.01.2012, 20:48 |
|
||
|
c# 4.0. Многопоточность и блокировки
|
|||
|---|---|---|---|
|
#18+
Testor1, попробую на досуге ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 30.01.2012, 06:08 |
|
||
|
c# 4.0. Многопоточность и блокировки
|
|||
|---|---|---|---|
|
#18+
Пока не запускал, общая идея см под спойлером. Я не очень хорошо знаю C# и TPL, так что кое-что тут коряво Можно исходники вот этих функций и create table для таблички-получателя? Код: c# 1. 2. 3. Код: 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. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 31.01.2012, 14:21 |
|
||
|
c# 4.0. Многопоточность и блокировки
|
|||
|---|---|---|---|
|
#18+
Адаптируй ранее высланый код под конкретную задачу (из последних сообщений) Код: 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. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 01.02.2012, 10:17 |
|
||
|
c# 4.0. Многопоточность и блокировки
|
|||
|---|---|---|---|
|
#18+
Testor1, Разбор писал с 0 (importRecord vs importRecord_old) твои параметры параллелизма не использую, а захардкодил: processWritePortion(sr, 2, 5000, ref currentTask) 2 - количество параллельных задач разбора 5000 - количество строчек в одной задаче То есть, в данном случае, разберет 2мя нитями 10000 строк, а потом их вставит. Код: 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. 327. 328. 329. 330. 331. 332. 333. 334. 335. 336. 337. 338. 339. 340. 341. 342. 343. 344. 345. 346. 347. 348. 349. 350. 351. 352. 353. 354. 355. 356. 357. 358. 359. 360. 361. 362. 363. 364. 365. 366. 367. 368. 369. 370. 371. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 05.02.2012, 13:50 |
|
||
|
c# 4.0. Многопоточность и блокировки
|
|||
|---|---|---|---|
|
#18+
СТРАННОЕ МЕСТОTestor1, Разбор писал с 0 (importRecord vs importRecord_old) твои параметры параллелизма не использую, а захардкодил: processWritePortion(sr, 2, 5000, ref currentTask) 2 - количество параллельных задач разбора 5000 - количество строчек в одной задаче То есть, в данном случае, разберет 2мя нитями 10000 строк, а потом их вставит. 1. Проверил, что загруженные данные не искаженны? 2. Какова скорость загрузки ? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 05.02.2012, 16:39 |
|
||
|
c# 4.0. Многопоточность и блокировки
|
|||
|---|---|---|---|
|
#18+
Testor1, Мельком глянул - похоже количество, количество строчек - совпадает Скорость не мерял. В процессе глянул на перформанс монитор - узкое место - диск. Но, может не попал на что-то. Теоретически оно должно писать и готовить следующую порцию одновременно, но если есть кто поопытнее - пусть поправит ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 05.02.2012, 22:12 |
|
||
|
c# 4.0. Многопоточность и блокировки
|
|||
|---|---|---|---|
|
#18+
странное местоTestor1, Мельком глянул - похоже количество, количество строчек - совпадает Скорость не мерял. В процессе глянул на перформанс монитор - узкое место - диск. Но, может не попал на что-то. Теоретически оно должно писать и готовить следующую порцию одновременно, но если есть кто поопытнее - пусть поправит Проверь что данные не исказились Что во всех строчках они одинаковые. У меня с этим была проблема. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 06.02.2012, 10:43 |
|
||
|
c# 4.0. Многопоточность и блокировки
|
|||
|---|---|---|---|
|
#18+
Testor1Проверь что данные не исказились Что во всех строчках они одинаковые. У меня с этим была проблема. Проверил на 80к - все нормально ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 07.02.2012, 08:29 |
|
||
|
c# 4.0. Многопоточность и блокировки
|
|||
|---|---|---|---|
|
#18+
CTPAHHOE MECTOTestor1Проверь что данные не исказились Что во всех строчках они одинаковые. У меня с этим была проблема. Проверил на 80к - все нормально На днях проверю твой вариант. Спасибо за внимание !!! ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 08.02.2012, 14:27 |
|
||
|
|

start [/forum/topic.php?fid=16&msg=37628108&tid=1342459]: |
0ms |
get settings: |
14ms |
get forum list: |
22ms |
check forum access: |
7ms |
check topic access: |
7ms |
track hit: |
190ms |
get topic data: |
14ms |
get forum data: |
4ms |
get page messages: |
64ms |
get tp. blocked users: |
2ms |
| others: | 247ms |
| total: | 571ms |

| 0 / 0 |
