亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
12下一頁
最近訪問板塊 發(fā)新帖
查看: 5739 | 回復: 12
打印 上一主題 下一主題

[C++] libuv發(fā)送數(shù)據(jù)問題 [復制鏈接]

論壇徽章:
2
技術(shù)圖書徽章
日期:2014-04-15 16:30:27金牛座
日期:2014-06-06 16:20:49
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2015-08-27 10:53 |只看該作者 |倒序瀏覽
最近在了解libuv,有了一定的認識。但是,在發(fā)送數(shù)據(jù)的時候,碰上了點問題
背景:我發(fā)現(xiàn),在libuv網(wǎng)絡(luò)庫代碼中,沒有使用任何同步工具(mutex,condition,等等);就是說,網(wǎng)絡(luò)I/O不能用于多線程;
但是,我們在多線程環(huán)境下,我可以把數(shù)據(jù)安全的放到對應的I/O線程;但是,怎么觸發(fā)I/O線程去獲取這個數(shù)據(jù)并且發(fā)送出去?
我看代碼,write_cb只有在uv_write的時候可以注冊?

由于我剛剛了解,肯定有認識不足的地方(可能就是我自己看錯了),希望大俠能指點一二

謝謝

論壇徽章:
15
射手座
日期:2014-11-29 19:22:4915-16賽季CBA聯(lián)賽之青島
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16賽季CBA聯(lián)賽之四川
日期:2017-02-07 21:08:572015年亞冠紀念徽章
日期:2015-11-06 12:31:58每日論壇發(fā)貼之星
日期:2015-08-04 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-08-04 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-07-12 22:20:002015亞冠之浦和紅鉆
日期:2015-07-08 10:10:132015亞冠之大阪鋼巴
日期:2015-06-29 11:21:122015亞冠之廣州恒大
日期:2015-05-22 21:55:412015年亞洲杯之伊朗
日期:2015-04-10 16:28:25
2 [報告]
發(fā)表于 2015-08-27 13:38 |只看該作者
knull 發(fā)表于 2015-08-27 10:53
最近在了解libuv,有了一定的認識。但是,在發(fā)送數(shù)據(jù)的時候,碰上了點問題
背景:我發(fā)現(xiàn),在libuv網(wǎng)絡(luò)庫代 ...

每個連接,同時只能屬于一個線程,所以不要鎖。

連接池的管理過程要用鎖,當一個連接分配給一個線程后就不用鎖了。

論壇徽章:
2
技術(shù)圖書徽章
日期:2014-04-15 16:30:27金牛座
日期:2014-06-06 16:20:49
3 [報告]
發(fā)表于 2015-08-27 14:33 |只看該作者
回復 2# yulihua49
首先,謝謝你的回復;
我的問題是:一般情況下,epoll是一個線程;send是另一個線程;就是說,一個鏈接,肯定會有屬于兩個線程的情況;
另外,你說的一個鏈接,屬于一個線程,是不是太奢侈了

   

論壇徽章:
44
15-16賽季CBA聯(lián)賽之浙江
日期:2021-10-11 02:03:59程序設(shè)計版塊每日發(fā)帖之星
日期:2016-07-02 06:20:0015-16賽季CBA聯(lián)賽之新疆
日期:2016-04-25 10:55:452016科比退役紀念章
日期:2016-04-23 00:51:2315-16賽季CBA聯(lián)賽之山東
日期:2016-04-17 12:00:2815-16賽季CBA聯(lián)賽之福建
日期:2016-04-12 15:21:2915-16賽季CBA聯(lián)賽之遼寧
日期:2016-03-24 21:38:2715-16賽季CBA聯(lián)賽之福建
日期:2016-03-18 12:13:4015-16賽季CBA聯(lián)賽之佛山
日期:2016-02-05 00:55:2015-16賽季CBA聯(lián)賽之佛山
日期:2016-02-04 21:11:3615-16賽季CBA聯(lián)賽之天津
日期:2016-11-02 00:33:1215-16賽季CBA聯(lián)賽之浙江
日期:2017-01-13 01:31:49
4 [報告]
發(fā)表于 2015-08-27 14:46 |只看該作者
回復 1# knull

  1. $ grep -Rn pthread_mutex libuv
  2. libuv/configure.ac:46:AC_CHECK_LIB([pthread], [pthread_mutex_init])
  3. libuv/include/pthread-fixes.h:45:  pthread_mutex_t  mutex;
  4. libuv/include/uv-unix.h:134:typedef pthread_mutex_t uv_mutex_t;
  5. libuv/src/unix/fs.c:621:  static pthread_mutex_t lock = PTHREAD_MUTEX_INITIALIZER;
  6. libuv/src/unix/fs.c:622:  pthread_mutex_lock(&lock);
  7. libuv/src/unix/fs.c:679:  pthread_mutex_unlock(&lock);
  8. libuv/src/unix/fsevents.c:495:  static pthread_mutex_t global_init_mutex = PTHREAD_MUTEX_INITIALIZER;
  9. libuv/src/unix/fsevents.c:501:  pthread_mutex_lock(&global_init_mutex);
  10. libuv/src/unix/fsevents.c:567:  pthread_mutex_unlock(&global_init_mutex);
  11. libuv/src/unix/pthread-fixes.c:66:  pthread_mutex_init(&barrier->mutex, NULL);
  12. libuv/src/unix/pthread-fixes.c:73:  pthread_mutex_lock(&barrier->mutex);
  13. libuv/src/unix/pthread-fixes.c:79:    pthread_mutex_unlock(&barrier->mutex);
  14. libuv/src/unix/pthread-fixes.c:88:  pthread_mutex_unlock(&barrier->mutex);
  15. libuv/src/unix/pthread-fixes.c:95:  pthread_mutex_destroy(&barrier->mutex);
  16. libuv/src/unix/thread.c:91:  return -pthread_mutex_init(mutex, NULL);
  17. libuv/src/unix/thread.c:93:  pthread_mutexattr_t attr;
  18. libuv/src/unix/thread.c:96:  if (pthread_mutexattr_init(&attr))
  19. libuv/src/unix/thread.c:99:  if (pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_ERRORCHECK))
  20. libuv/src/unix/thread.c:102:  err = pthread_mutex_init(mutex, &attr);
  21. libuv/src/unix/thread.c:104:  if (pthread_mutexattr_destroy(&attr))
  22. libuv/src/unix/thread.c:113:  if (pthread_mutex_destroy(mutex))
  23. libuv/src/unix/thread.c:119:  if (pthread_mutex_lock(mutex))
  24. libuv/src/unix/thread.c:130:  err = pthread_mutex_trylock(mutex);
  25. libuv/src/unix/thread.c:139:  if (pthread_mutex_unlock(mutex))
復制代碼
誰說libuv沒用mutex?

論壇徽章:
15
射手座
日期:2014-11-29 19:22:4915-16賽季CBA聯(lián)賽之青島
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16賽季CBA聯(lián)賽之四川
日期:2017-02-07 21:08:572015年亞冠紀念徽章
日期:2015-11-06 12:31:58每日論壇發(fā)貼之星
日期:2015-08-04 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-08-04 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-07-12 22:20:002015亞冠之浦和紅鉆
日期:2015-07-08 10:10:132015亞冠之大阪鋼巴
日期:2015-06-29 11:21:122015亞冠之廣州恒大
日期:2015-05-22 21:55:412015年亞洲杯之伊朗
日期:2015-04-10 16:28:25
5 [報告]
發(fā)表于 2015-08-27 14:52 |只看該作者
本帖最后由 yulihua49 于 2015-08-27 15:01 編輯
knull 發(fā)表于 2015-08-27 14:33
回復 2# yulihua49
首先,謝謝你的回復;
我的問題是:一般情況下,epoll是一個線程;send是另一個線程; ...

1.epoll_wait可以是很多線程,但每個線程一次只可以得到一個連接。
2.如果epoll_wait一次獲取多個事件,它將分發(fā)到其他線程,分出去后,它就不再擁有它。所以還是一個線程在處理。
3.線程也可以從連接池獲取連接,在一定時間內(nèi),一個連接只屬于一個線程。

違背上述原則,一個連接同時被多個線程處理,就是“驚群”?如果你一定要這樣處理,就必須加鎖,一個完了再另一個,串行化。

論壇徽章:
15
射手座
日期:2014-11-29 19:22:4915-16賽季CBA聯(lián)賽之青島
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16賽季CBA聯(lián)賽之四川
日期:2017-02-07 21:08:572015年亞冠紀念徽章
日期:2015-11-06 12:31:58每日論壇發(fā)貼之星
日期:2015-08-04 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-08-04 06:20:00程序設(shè)計版塊每日發(fā)帖之星
日期:2015-07-12 22:20:002015亞冠之浦和紅鉆
日期:2015-07-08 10:10:132015亞冠之大阪鋼巴
日期:2015-06-29 11:21:122015亞冠之廣州恒大
日期:2015-05-22 21:55:412015年亞洲杯之伊朗
日期:2015-04-10 16:28:25
6 [報告]
發(fā)表于 2015-08-27 14:56 |只看該作者
windoze 發(fā)表于 2015-08-27 14:46
回復 1# knull 誰說libuv沒用mutex?

那些都應該是資源管理所用。真正的IO還要加鎖嗎?

論壇徽章:
44
15-16賽季CBA聯(lián)賽之浙江
日期:2021-10-11 02:03:59程序設(shè)計版塊每日發(fā)帖之星
日期:2016-07-02 06:20:0015-16賽季CBA聯(lián)賽之新疆
日期:2016-04-25 10:55:452016科比退役紀念章
日期:2016-04-23 00:51:2315-16賽季CBA聯(lián)賽之山東
日期:2016-04-17 12:00:2815-16賽季CBA聯(lián)賽之福建
日期:2016-04-12 15:21:2915-16賽季CBA聯(lián)賽之遼寧
日期:2016-03-24 21:38:2715-16賽季CBA聯(lián)賽之福建
日期:2016-03-18 12:13:4015-16賽季CBA聯(lián)賽之佛山
日期:2016-02-05 00:55:2015-16賽季CBA聯(lián)賽之佛山
日期:2016-02-04 21:11:3615-16賽季CBA聯(lián)賽之天津
日期:2016-11-02 00:33:1215-16賽季CBA聯(lián)賽之浙江
日期:2017-01-13 01:31:49
7 [報告]
發(fā)表于 2015-08-27 15:10 |只看該作者
回復 6# yulihua49

最基本的I/O,比如read/write,不一定是原子操作,所以加鎖是必須的。

論壇徽章:
2
技術(shù)圖書徽章
日期:2014-04-15 16:30:27金牛座
日期:2014-06-06 16:20:49
8 [報告]
發(fā)表于 2015-08-28 11:04 |只看該作者
windoze 發(fā)表于 2015-08-27 14:46
回復 1# knull 誰說libuv沒用mutex?

謝謝你的回復啊,熱心的朋友;
我的意思是,libuv庫中,網(wǎng)絡(luò)I/O相關(guān)代碼,是 沒有用 到鎖;并不是說它 沒有 。
libuv本身是提供這些同步工具,但是在I/O中沒有用到;在線程池等地方,用了。

論壇徽章:
2
技術(shù)圖書徽章
日期:2014-04-15 16:30:27金牛座
日期:2014-06-06 16:20:49
9 [報告]
發(fā)表于 2015-08-28 11:11 |只看該作者
回復 5# yulihua49
再次感謝;但是,我不是很能理解
你說的模型,是不是一個epoll_wait就管理一個鏈接?然后,一個線程管理一個epoll?
一般的模型,不都是N多個鏈接,放在一個epoll中管理;有事件過來,那么就激活這個鏈接?
如果是我說的模型,要將數(shù)據(jù)分發(fā)到其他work線程,那么還是需要鎖的,這個似乎沒有異議。
但是,其他線程處理完數(shù)據(jù)之后,要對對應的鏈接發(fā)送數(shù)據(jù),可以直接用uv_write;但是,我測試發(fā)現(xiàn),如果uv_write和epoll線程不是同一個的話,是存在問題的(雖然,我也覺得,理論上是不應該有問題的)。暫時,沒有找到問題根本原因?但是,現(xiàn)象是,epoll_wait觸發(fā)了寫事件,導致兩個線程同時寫;但是,寫隊列沒有鎖,所以就掛壁了。

   

論壇徽章:
36
子鼠
日期:2013-08-28 22:23:29黃金圣斗士
日期:2015-12-01 11:37:51程序設(shè)計版塊每日發(fā)帖之星
日期:2015-12-14 06:20:00CU十四周年紀念徽章
日期:2015-12-22 16:50:40IT運維版塊每日發(fā)帖之星
日期:2016-01-25 06:20:0015-16賽季CBA聯(lián)賽之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16賽季CBA聯(lián)賽之福建
日期:2016-04-07 11:25:2215-16賽季CBA聯(lián)賽之青島
日期:2016-04-29 18:02:5915-16賽季CBA聯(lián)賽之北控
日期:2016-06-20 17:38:50技術(shù)圖書徽章
日期:2016-07-19 13:54:03程序設(shè)計版塊每日發(fā)帖之星
日期:2016-08-21 06:20:00
10 [報告]
發(fā)表于 2015-08-28 15:38 |只看該作者
可以放加鎖的隊列,開個uv的timer在io線程里發(fā)
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP