fix #142, tcp stat slow bug, use /proc/net/sockstat instead, refer to 'ss -s'. 0.9.183.
正在显示
5 个修改的文件
包含
58 行增加
和
55 行删除
@@ -207,6 +207,7 @@ Supported operating systems and hardware: | @@ -207,6 +207,7 @@ Supported operating systems and hardware: | ||
207 | * 2013-10-17, Created.<br/> | 207 | * 2013-10-17, Created.<br/> |
208 | 208 | ||
209 | ## History | 209 | ## History |
210 | +* v1.0, 2014-08-02, fix [#142](https://github.com/winlinvip/simple-rtmp-server/issues/142), fix tcp stat slow bug, use /proc/net/sockstat instead, refer to 'ss -s'. 0.9.183. | ||
210 | * v1.0, 2014-07-31, fix [#141](https://github.com/winlinvip/simple-rtmp-server/issues/141), support tun0(vpn network device) ip retrieve. 0.9.179. | 211 | * v1.0, 2014-07-31, fix [#141](https://github.com/winlinvip/simple-rtmp-server/issues/141), support tun0(vpn network device) ip retrieve. 0.9.179. |
211 | * v1.0, 2014-07-27, support build on OSX(Darwin). 0.9.177 | 212 | * v1.0, 2014-07-27, support build on OSX(Darwin). 0.9.177 |
212 | * v1.0, 2014-07-27, api connections add udp, add disk iops. 0.9.176 | 213 | * v1.0, 2014-07-27, api connections add udp, add disk iops. 0.9.176 |
@@ -68,6 +68,10 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | @@ -68,6 +68,10 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||
68 | // SRS_SYS_CYCLE_INTERVAL * SRS_SYS_RUSAGE_RESOLUTION_TIMES | 68 | // SRS_SYS_CYCLE_INTERVAL * SRS_SYS_RUSAGE_RESOLUTION_TIMES |
69 | #define SRS_SYS_RUSAGE_RESOLUTION_TIMES 30 | 69 | #define SRS_SYS_RUSAGE_RESOLUTION_TIMES 30 |
70 | 70 | ||
71 | +// update network devices info interval: | ||
72 | +// SRS_SYS_CYCLE_INTERVAL * SRS_SYS_NETWORK_RTMP_SERVER_RESOLUTION_TIMES | ||
73 | +#define SRS_SYS_NETWORK_RTMP_SERVER_RESOLUTION_TIMES 30 | ||
74 | + | ||
71 | // update rusage interval: | 75 | // update rusage interval: |
72 | // SRS_SYS_CYCLE_INTERVAL * SRS_SYS_CPU_STAT_RESOLUTION_TIMES | 76 | // SRS_SYS_CYCLE_INTERVAL * SRS_SYS_CPU_STAT_RESOLUTION_TIMES |
73 | #define SRS_SYS_CPU_STAT_RESOLUTION_TIMES 30 | 77 | #define SRS_SYS_CPU_STAT_RESOLUTION_TIMES 30 |
@@ -88,10 +92,6 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | @@ -88,10 +92,6 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||
88 | // SRS_SYS_CYCLE_INTERVAL * SRS_SYS_NETWORK_DEVICE_RESOLUTION_TIMES | 92 | // SRS_SYS_CYCLE_INTERVAL * SRS_SYS_NETWORK_DEVICE_RESOLUTION_TIMES |
89 | #define SRS_SYS_NETWORK_DEVICE_RESOLUTION_TIMES 90 | 93 | #define SRS_SYS_NETWORK_DEVICE_RESOLUTION_TIMES 90 |
90 | 94 | ||
91 | -// update network devices info interval: | ||
92 | -// SRS_SYS_CYCLE_INTERVAL * SRS_SYS_NETWORK_RTMP_SERVER_RESOLUTION_TIMES | ||
93 | -#define SRS_SYS_NETWORK_RTMP_SERVER_RESOLUTION_TIMES 90 | ||
94 | - | ||
95 | SrsListener::SrsListener(SrsServer* server, SrsListenerType type) | 95 | SrsListener::SrsListener(SrsServer* server, SrsListenerType type) |
96 | { | 96 | { |
97 | fd = -1; | 97 | fd = -1; |
@@ -781,7 +781,7 @@ SrsNetworkRtmpServer::SrsNetworkRtmpServer() | @@ -781,7 +781,7 @@ SrsNetworkRtmpServer::SrsNetworkRtmpServer() | ||
781 | ok = false; | 781 | ok = false; |
782 | sample_time = rbytes = sbytes = 0; | 782 | sample_time = rbytes = sbytes = 0; |
783 | nb_conn_sys = nb_conn_srs = 0; | 783 | nb_conn_sys = nb_conn_srs = 0; |
784 | - nb_conn_sys_et = nb_conn_sys_tw = nb_conn_sys_ls = 0; | 784 | + nb_conn_sys_et = nb_conn_sys_tw = 0; |
785 | nb_conn_sys_udp = 0; | 785 | nb_conn_sys_udp = 0; |
786 | } | 786 | } |
787 | 787 | ||
@@ -813,13 +813,18 @@ void srs_update_rtmp_server(int nb_conn, SrsKbps* kbps) | @@ -813,13 +813,18 @@ void srs_update_rtmp_server(int nb_conn, SrsKbps* kbps) | ||
813 | { | 813 | { |
814 | SrsNetworkRtmpServer& r = _srs_network_rtmp_server; | 814 | SrsNetworkRtmpServer& r = _srs_network_rtmp_server; |
815 | 815 | ||
816 | - // reset total. | ||
817 | - r.nb_conn_sys = 0; | 816 | + int nb_socks = 0; |
817 | + int nb_tcp4_hashed = 0; | ||
818 | + int nb_tcp_orphans = 0; | ||
819 | + int nb_tcp_tws = 0; | ||
820 | + int nb_tcp_total = 0; | ||
821 | + int nb_tcp_mem = 0; | ||
822 | + int nb_udp4 = 0; | ||
818 | 823 | ||
819 | if (true) { | 824 | if (true) { |
820 | - FILE* f = fopen("/proc/net/tcp", "r"); | 825 | + FILE* f = fopen("/proc/net/sockstat", "r"); |
821 | if (f == NULL) { | 826 | if (f == NULL) { |
822 | - srs_warn("open proc network tcp failed, ignore"); | 827 | + srs_warn("open proc network sockstat failed, ignore"); |
823 | return; | 828 | return; |
824 | } | 829 | } |
825 | 830 | ||
@@ -827,45 +832,31 @@ void srs_update_rtmp_server(int nb_conn, SrsKbps* kbps) | @@ -827,45 +832,31 @@ void srs_update_rtmp_server(int nb_conn, SrsKbps* kbps) | ||
827 | static char buf[1024]; | 832 | static char buf[1024]; |
828 | fgets(buf, sizeof(buf), f); | 833 | fgets(buf, sizeof(buf), f); |
829 | 834 | ||
830 | - int nb_conn_sys_established = 0; | ||
831 | - int nb_conn_sys_time_wait = 0; | ||
832 | - int nb_conn_sys_listen = 0; | ||
833 | - int nb_conn_sys_other = 0; | ||
834 | - | ||
835 | - // @see: http://tester-higkoo.googlecode.com/svn-history/r14/trunk/Tools/iostat/iostat.c | 835 | + // @see: https://github.com/shemminger/iproute2/blob/master/misc/ss.c |
836 | while (fgets(buf, sizeof(buf), f)) { | 836 | while (fgets(buf, sizeof(buf), f)) { |
837 | - int st = 0; | ||
838 | - int ret = sscanf(buf, "%*s %*s %*s %2x\n", &st); | ||
839 | - | ||
840 | - if (ret == 1) { | ||
841 | - if (st == SYS_TCP_ESTABLISHED) { | ||
842 | - nb_conn_sys_established++; | ||
843 | - } else if (st == SYS_TCP_TIME_WAIT) { | ||
844 | - nb_conn_sys_time_wait++; | ||
845 | - } else if (st == SYS_TCP_LISTEN) { | ||
846 | - nb_conn_sys_listen++; | ||
847 | - } else { | ||
848 | - nb_conn_sys_other++; | ||
849 | - } | ||
850 | - } | ||
851 | - | ||
852 | - if (ret == EOF) { | ||
853 | - break; | 837 | + // @see: get_sockstat_line() |
838 | + if (strncmp(buf, "sockets: used ", 14) == 0) { | ||
839 | + int ret = sscanf(buf, "%*s %*s %d\n", &nb_socks); | ||
840 | + srs_assert(ret == 1); | ||
841 | + } else if (strncmp(buf, "TCP: ", 5) == 0) { | ||
842 | + int ret = sscanf(buf, "%*s %*s %d %*s %d %*s %d %*s %d %*s %d\n", | ||
843 | + &nb_tcp4_hashed, &nb_tcp_orphans, &nb_tcp_tws, &nb_tcp_total, &nb_tcp_mem); | ||
844 | + srs_assert(ret == 5); | ||
845 | + } else if (strncmp(buf, "UDP: ", 5) == 0) { | ||
846 | + int ret = sscanf(buf, "%*s %*s %d\n", &nb_udp4); | ||
847 | + srs_assert(ret == 1); | ||
854 | } | 848 | } |
855 | } | 849 | } |
856 | 850 | ||
857 | - r.nb_conn_sys = nb_conn_sys_established + nb_conn_sys_time_wait + nb_conn_sys_listen + nb_conn_sys_other; | ||
858 | - r.nb_conn_sys_et = nb_conn_sys_established; | ||
859 | - r.nb_conn_sys_tw = nb_conn_sys_time_wait; | ||
860 | - r.nb_conn_sys_ls = nb_conn_sys_listen; | ||
861 | - | ||
862 | fclose(f); | 851 | fclose(f); |
863 | } | 852 | } |
864 | 853 | ||
854 | + int nb_tcp_estab = 0; | ||
855 | + | ||
865 | if (true) { | 856 | if (true) { |
866 | - FILE* f = fopen("/proc/net/udp", "r"); | 857 | + FILE* f = fopen("/proc/net/snmp", "r"); |
867 | if (f == NULL) { | 858 | if (f == NULL) { |
868 | - srs_warn("open proc network udp failed, ignore"); | 859 | + srs_warn("open proc network snmp failed, ignore"); |
869 | return; | 860 | return; |
870 | } | 861 | } |
871 | 862 | ||
@@ -873,27 +864,36 @@ void srs_update_rtmp_server(int nb_conn, SrsKbps* kbps) | @@ -873,27 +864,36 @@ void srs_update_rtmp_server(int nb_conn, SrsKbps* kbps) | ||
873 | static char buf[1024]; | 864 | static char buf[1024]; |
874 | fgets(buf, sizeof(buf), f); | 865 | fgets(buf, sizeof(buf), f); |
875 | 866 | ||
876 | - // all udp is close state. | ||
877 | - int nb_conn_sys_close = 0; | ||
878 | - | ||
879 | - // @see: http://tester-higkoo.googlecode.com/svn-history/r14/trunk/Tools/iostat/iostat.c | 867 | + // @see: https://github.com/shemminger/iproute2/blob/master/misc/ss.c |
880 | while (fgets(buf, sizeof(buf), f)) { | 868 | while (fgets(buf, sizeof(buf), f)) { |
881 | - int st = 0; | ||
882 | - int ret = sscanf(buf, "%*s %*s %*s %2x\n", &st); | ||
883 | - | ||
884 | - if (ret == EOF) { | 869 | + // @see: get_snmp_int("Tcp:", "CurrEstab", &sn.tcp_estab) |
870 | + // tcp stat title | ||
871 | + if (strncmp(buf, "Tcp: ", 5) == 0) { | ||
872 | + // read tcp stat data | ||
873 | + if (!fgets(buf, sizeof(buf), f)) { | ||
885 | break; | 874 | break; |
886 | } | 875 | } |
887 | - | ||
888 | - nb_conn_sys_close++; | 876 | + // parse tcp stat data |
877 | + if (strncmp(buf, "Tcp: ", 5) == 0) { | ||
878 | + int ret = sscanf(buf, "%*s %*d %*d %*d %*d %*d %*d %*d %*d %d\n", &nb_tcp_estab); | ||
879 | + srs_assert(ret == 1); | ||
880 | + } | ||
881 | + } | ||
889 | } | 882 | } |
890 | - | ||
891 | - r.nb_conn_sys += nb_conn_sys_close; | ||
892 | - r.nb_conn_sys_udp = nb_conn_sys_close; | ||
893 | 883 | ||
894 | fclose(f); | 884 | fclose(f); |
895 | } | 885 | } |
896 | 886 | ||
887 | + // @see: https://github.com/shemminger/iproute2/blob/master/misc/ss.c | ||
888 | + // TODO: FIXME: ignore the slabstat, @see: get_slabstat() | ||
889 | + if (true) { | ||
890 | + // @see: print_summary() | ||
891 | + r.nb_conn_sys = nb_tcp_total + nb_tcp_tws; | ||
892 | + r.nb_conn_sys_et = nb_tcp_estab; | ||
893 | + r.nb_conn_sys_tw = nb_tcp_tws; | ||
894 | + r.nb_conn_sys_udp = nb_udp4; | ||
895 | + } | ||
896 | + | ||
897 | if (true) { | 897 | if (true) { |
898 | r.ok = true; | 898 | r.ok = true; |
899 | 899 | ||
@@ -1113,7 +1113,6 @@ void srs_api_dump_summaries(std::stringstream& ss) | @@ -1113,7 +1113,6 @@ void srs_api_dump_summaries(std::stringstream& ss) | ||
1113 | << __SRS_JFIELD_ORG("conn_sys", nrs->nb_conn_sys) << __SRS_JFIELD_CONT | 1113 | << __SRS_JFIELD_ORG("conn_sys", nrs->nb_conn_sys) << __SRS_JFIELD_CONT |
1114 | << __SRS_JFIELD_ORG("conn_sys_et", nrs->nb_conn_sys_et) << __SRS_JFIELD_CONT | 1114 | << __SRS_JFIELD_ORG("conn_sys_et", nrs->nb_conn_sys_et) << __SRS_JFIELD_CONT |
1115 | << __SRS_JFIELD_ORG("conn_sys_tw", nrs->nb_conn_sys_tw) << __SRS_JFIELD_CONT | 1115 | << __SRS_JFIELD_ORG("conn_sys_tw", nrs->nb_conn_sys_tw) << __SRS_JFIELD_CONT |
1116 | - << __SRS_JFIELD_ORG("conn_sys_ls", nrs->nb_conn_sys_ls) << __SRS_JFIELD_CONT | ||
1117 | << __SRS_JFIELD_ORG("conn_sys_udp", nrs->nb_conn_sys_udp) << __SRS_JFIELD_CONT | 1116 | << __SRS_JFIELD_ORG("conn_sys_udp", nrs->nb_conn_sys_udp) << __SRS_JFIELD_CONT |
1118 | << __SRS_JFIELD_ORG("conn_srs", nrs->nb_conn_srs) | 1117 | << __SRS_JFIELD_ORG("conn_srs", nrs->nb_conn_srs) |
1119 | << __SRS_JOBJECT_END | 1118 | << __SRS_JOBJECT_END |
@@ -595,11 +595,14 @@ public: | @@ -595,11 +595,14 @@ public: | ||
595 | int skbps_5m; | 595 | int skbps_5m; |
596 | 596 | ||
597 | // connections | 597 | // connections |
598 | + // @see: /proc/net/snmp | ||
599 | + // @see: /proc/net/sockstat | ||
598 | int nb_conn_sys; | 600 | int nb_conn_sys; |
599 | int nb_conn_sys_et; // established | 601 | int nb_conn_sys_et; // established |
600 | int nb_conn_sys_tw; // time wait | 602 | int nb_conn_sys_tw; // time wait |
601 | - int nb_conn_sys_ls; // listen | ||
602 | int nb_conn_sys_udp; // udp | 603 | int nb_conn_sys_udp; // udp |
604 | + | ||
605 | + // retrieve from srs interface | ||
603 | int nb_conn_srs; | 606 | int nb_conn_srs; |
604 | 607 | ||
605 | public: | 608 | public: |
@@ -31,7 +31,7 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | @@ -31,7 +31,7 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||
31 | // current release version | 31 | // current release version |
32 | #define VERSION_MAJOR "0" | 32 | #define VERSION_MAJOR "0" |
33 | #define VERSION_MINOR "9" | 33 | #define VERSION_MINOR "9" |
34 | -#define VERSION_REVISION "182" | 34 | +#define VERSION_REVISION "183" |
35 | #define RTMP_SIG_SRS_VERSION VERSION_MAJOR"."VERSION_MINOR"."VERSION_REVISION | 35 | #define RTMP_SIG_SRS_VERSION VERSION_MAJOR"."VERSION_MINOR"."VERSION_REVISION |
36 | // server info. | 36 | // server info. |
37 | #define RTMP_SIG_SRS_KEY "SRS" | 37 | #define RTMP_SIG_SRS_KEY "SRS" |
-
请 注册 或 登录 后发表评论