mirror of
https://github.com/ossrs/srs.git
synced 2025-03-09 15:49:59 +00:00
SmartPtr: Support load test for source by srs-bench. v6.0.130 (#4097)
1. Add live benchmark support in srs-bench, which only connects and disconnects without any media transport, to test source creation and disposal and verify source memory leaks. 2. SmartPtr: Support cleanup of HTTP-FLV stream. Unregister the HTTP-FLV handler for the pattern and clean up the objects and resources. 3. Support benchmarking RTMP/SRT with srs-bench by integrating the gosrt and oryx RTMP libraries. 4. Refine SRT and RTC sources by using a timer to clean up the sources, following the same strategy as the Live source. --------- Co-authored-by: Haibo Chen <495810242@qq.com> Co-authored-by: Jacob Su <suzp1984@gmail.com>
This commit is contained in:
parent
e3d74fb045
commit
1f9309ae25
508 changed files with 6805 additions and 3299 deletions
69
trunk/3rdparty/srs-bench/vendor/github.com/haivision/srtgo/accept.go
generated
vendored
Normal file
69
trunk/3rdparty/srs-bench/vendor/github.com/haivision/srtgo/accept.go
generated
vendored
Normal file
|
|
@ -0,0 +1,69 @@
|
|||
package srtgo
|
||||
|
||||
/*
|
||||
#cgo LDFLAGS: -lsrt
|
||||
#include <srt/srt.h>
|
||||
|
||||
SRTSOCKET srt_accept_wrapped(SRTSOCKET lsn, struct sockaddr* addr, int* addrlen, int *srterror, int *syserror)
|
||||
{
|
||||
int ret = srt_accept(lsn, addr, addrlen);
|
||||
if (ret < 0) {
|
||||
*srterror = srt_getlasterror(syserror);
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
*/
|
||||
import "C"
|
||||
import (
|
||||
"fmt"
|
||||
"net"
|
||||
"syscall"
|
||||
"unsafe"
|
||||
)
|
||||
|
||||
func srtAcceptImpl(lsn C.SRTSOCKET, addr *C.struct_sockaddr, addrlen *C.int) (C.SRTSOCKET, error) {
|
||||
srterr := C.int(0)
|
||||
syserr := C.int(0)
|
||||
socket := C.srt_accept_wrapped(lsn, addr, addrlen, &srterr, &syserr)
|
||||
if srterr != 0 {
|
||||
srterror := SRTErrno(srterr)
|
||||
if syserr < 0 {
|
||||
srterror.wrapSysErr(syscall.Errno(syserr))
|
||||
}
|
||||
return socket, srterror
|
||||
}
|
||||
return socket, nil
|
||||
}
|
||||
|
||||
// Accept an incoming connection
|
||||
func (s SrtSocket) Accept() (*SrtSocket, *net.UDPAddr, error) {
|
||||
var err error
|
||||
if !s.blocking {
|
||||
err = s.pd.wait(ModeRead)
|
||||
if err != nil {
|
||||
return nil, nil, err
|
||||
}
|
||||
}
|
||||
var addr syscall.RawSockaddrAny
|
||||
sclen := C.int(syscall.SizeofSockaddrAny)
|
||||
socket, err := srtAcceptImpl(s.socket, (*C.struct_sockaddr)(unsafe.Pointer(&addr)), &sclen)
|
||||
if err != nil {
|
||||
return nil, nil, err
|
||||
}
|
||||
if socket == SRT_INVALID_SOCK {
|
||||
return nil, nil, fmt.Errorf("srt accept, error accepting the connection: %w", srtGetAndClearError())
|
||||
}
|
||||
|
||||
newSocket, err := newFromSocket(&s, socket)
|
||||
if err != nil {
|
||||
return nil, nil, fmt.Errorf("new socket could not be created: %w", err)
|
||||
}
|
||||
|
||||
udpAddr, err := udpAddrFromSockaddr(&addr)
|
||||
if err != nil {
|
||||
return nil, nil, err
|
||||
}
|
||||
|
||||
return newSocket, udpAddr, nil
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue