[TOC]
# 聲明:
這里完全是按照這篇博客安裝部署的
```
https://blog.csdn.net/fightfaith/article/details/73276323
```
# 安裝配置turnserver
## 第1章 相關鏈接
```
https://github.com/coturn/coturn
https://github.com/coturn/coturn/wiki/turnserver
https://github.com/coturn/coturn/blob/master/INSTALL
```
## 第2章 安裝配置
### 2.1 安裝
```
[root@webrtc-80 ~]# apt-get update
[root@webrtc-80 ~]# apt-get install coturn -y
[root@webrtc-80 ~]# dpkg -L coturn
```
### 2.2 配置
#### 2.2.1 配置文件路徑
```
/etc/turnserver.conf
```
#### 2.2.2 配置修改內容
```
18 listening-port=3478
30 tls-listening-port=5349
52 listening-ip=192.168.47.80
97 relay-ip=192.168.47.80
120 external-ip=192.168.47.80
217 server-name=test.com
317 realm=test.com
166 lt-cred-mech
260 userdb=/var/lib/turn/turndb
396 cert=/etc/turn_server_cert.pem
403 pkey=/etc/turn_server_pkey.pem
446 no-stdout-log
459 log-file=/var/tmp/turnserver.log
558 pidfile="/var/run/turnserver.pid"
```
#### 2.2.3 配置字段含義
```
listening-port: turnserver監聽UDP/TCP端口,默認為3478;
tls-listening-port: turnserver監聽TLS/DTLS端口,默認為5349,
將TCP/UDP和TLS/DTLS分別定義監聽端口是符合RFC5766規范的,但是通過配置兩者能使用同一端口,不推薦;
listening-ip: 中繼服務器的監聽IP地址,可以配置多個;
relay-ip: 中繼服務器的IP地址;
external-ip: 外部IP,當中繼服務器在NAT網絡內部時指定,此處可以不添加;
server-name: 服務器名稱,用于OAuth認證,默認和realm相同;
realm: 域名;
userdb: 用于保存用戶信息;
cert/pkey: 自簽名證書相關;
```
#### 2.2.4 注意事項
```
1) coturn使用了SQLlite作為存儲,請保證userdb的正確配置(userdb=/var/lib/turn/turndb),不需要添加turnuserdb.conf文件(turnuserdb.conf多用于restund的配置方式);
2) cert和pkey配置的自簽名證書用Openssl命令生成
openssl req -x509 -newkey rsa:2048 -keyout /etc/turn_server_pkey.pem -out /etc/turn_server_cert.pem -days 99999 -nodes
3) 配置成功后生成用戶名/密碼
turnadmin -k -u -r -p //turnadmin -k -a -u btzh -r ice.btzh.net -p webrtc
執行上述命令后,會創建一個用戶/密碼,并添加到SQLlite數據庫中.
參數含義請參見
man turnadmin
```
#### 2.2.5 證書生成過程
```
[root@webrtc-80 ~]# openssl req -x509 -newkey rsa:2048 -keyout /etc/turn_server_pkey.pem -out /etc/turn_server_cert.pem -days 99999 -nodes
[root@webrtc-80 ~]# turnadmin -k -u -r -p //turnadmin -k -a -u btzh -r ice.btzh.net -p webrtc
0: log file opened: /var/log/turn_18903_2018-04-08.log
0: Config file found: /root/../etc/turnuserdb.conf
[root@webrtc-80 ~]# ll /etc/turn_server_*
-rw-r--r-- 1 root root 1.7K Apr 8 17:26 /etc/turn_server_pkey.pem
-rw-r--r-- 1 root root 1.3K Apr 8 17:26 /etc/turn_server_cert.pem
```
## 2.3 啟動服務
后臺啟動,這里后臺啟動失敗,原因未確定
```
service coturn start
```
前臺啟動
```
turnserver
```
初次運行請使用非后臺啟動,會顯示當前運行狀態,如果有錯誤會直接顯示在控制臺上.
```
[root@webrtc-80 ~]# turnserver
0: log file opened: /var/log/turn_18927_2018-04-08.log
0:
RFC 3489/5389/5766/5780/6062/6156 STUN/TURN Server
Version Coturn-4.2.1.2 'Monza'
0:
Max number of open files/sockets allowed for this process: 65536
0:
Due to the open files/sockets limitation,
max supported number of TURN Sessions possible is: 32500 (approximately)
0:
==== Show him the instruments, Practical Frost: ====
0: TLS supported
0: DTLS supported
0: AEAD supported
0: Redis supported
0: PostgreSQL supported
0: MySQL supported
0: MongoDB is not supported
0: OpenSSL compile-time version 0x1000105f: fresh enough
0: Default Net Engine version: 2 (UDP thread per network endpoint)
=====================================================
0: Config file found: /root/../etc/turnserver.conf
0: Listener address to use: 192.168.47.80
0: Relay address to use: 192.168.47.80
```
## 2.4 驗證監聽
```
[root@webrtc-80 ~]# lsof -n -i4TCP:3478 | grep LISTEN
turnserve 18927 root 27u IPv4 31966 0t0 TCP 192.168.47.80:3478 (LISTEN)
[root@webrtc-80 ~]# lsof -n -i4TCP:5349 | grep LISTEN
turnserve 18927 root 28u IPv4 31967 0t0 TCP 192.168.47.80:5349 (LISTEN)
```
## 2.5 驗證服務
```
[root@webrtc-80 ~]# echo "192.168.47.80 test.com" >> /etc/hosts
[root@webrtc-80 ~]# ping test.com
PING test.com (192.168.47.80) 56(84) bytes of data.
64 bytes from test.com (192.168.47.80): icmp_seq=1 ttl=64 time=0.014 ms
[root@webrtc-80 ~]# curl 192.168.47.80:3478
<!DOCTYPE html>
<html>
<head>
<title>TURN Server</title>
</head>
<body>
TURN Server
</body>
</html>
[root@webrtc-80 ~]# curl test.com:3478
<!DOCTYPE html>
<html>
<head>
<title>TURN Server</title>
</head>
<body>
TURN Server
</body>
</html>
```
網頁訪問綁定hosts后訪問http://test.com:3478
```

```
## 2.6 查看日志
```
[root@webrtc-80 ~]# tail -f /var/tmp/turnserver_2018-04-08.log
0: IO method (udp listener/relay thread): epoll (with changelist)
0: IO method (general relay thread): epoll (with changelist)
0: turn server id=1 created
0: turn server id=128 created
0: IO method (udp listener/relay thread): epoll (with changelist)
0: turn server id=129 created
0: Total UDP servers: 2
0: Total General servers: 2
0: IO method (auth thread): epoll (with changelist)
0: IO method (cli thread): epoll (with changelist)
15: read_client_connection: HTTP request: GET / HTTP/1.1
Host: test.com:3478
Connection: keep-alive
Upgrade-Insecure-Requests: 1
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/64.0.3282.119 Safari/537.36
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8
Accept-Encoding: gzip, deflate
Accept-Language: zh-CN,zh;q=0.9
```
- 運維筆記
- 零: 安裝部署篇
- Zabbix
- HAproxy
- Nginx
- Apache
- Tomcat
- Mysql
- Redis
- ELK
- MongoDB
- hadoop
- GIt
- JDK
- Docker
- OpenVPN
- iRedMail
- GitLab
- ESXi
- Jenkins
- NFS
- rsync
- Python
- Keepalived
- 軟件打包篇
- 私有倉庫篇
- kafka
- zookeeper
- Spark
- Linux基礎篇
- 1.1 Linux系統介紹
- 1.3 系統優化
- 1.4 問題總結
- Linux核心命令
- 聲明
- 1-文件和目錄操作命令
- 1.3 tree: 以樹形結構顯示目錄下的內容
- 2-文件過濾及內容編輯處理命令
- find:查找目錄下的文件
- 3-文本處理三劍客
- 4-Linux信息顯示與搜索文件命令
- du:統計磁盤空間使用情況
- 5-文件備份與壓縮命令
- rsync:文件同步工具
- 6-Linux用戶管理及用戶信息查詢命令
- 7-Linux磁盤與文件系統管理命令
- 8-Linux進程管理命令
- 9-Linux網絡管理命令
- 10-Linux系統管理命令
- 11-Linux系統常用內置命令
- 服務相關
- Nginx
- 安裝部署
- 文件路徑說明
- 服務啟動管理
- 配置文件說明
- json格式日志的配置文件
- https代理
- nginx負載均衡代理websocket
- 服務優化
- 維護腳本
- 問題總結
- rewrite帶?跳轉
- nginx查看默認安裝的模塊
- HAproxy
- 2.2.1 安裝部署
- 2.2.2 文件路徑說明
- 2.2.3 服務啟動管理
- 2.2.4 配置文件說明
- ha代理websocket
- 2.2.5 集群高可用
- 2.2.6 服務優化
- 2.2.7 維護腳本
- 2.2.8 問題總結
- PHP
- 2.3.1 安裝部署
- keepalived
- 配置文件注釋
- 配置多組VIP
- Java
- 安裝部署java
- ansible部署java
- supervisor
- supervisor安裝部署測試
- iptables
- CentOS7安裝配置iptables
- pm2相關
- kafka相關
- kafka和zookeeper集群安裝部署
- nodejs
- 安裝部署nodejs
- sersync
- sersync備份圖片服務
- gitlab相關
- gitlab安裝部署
- gitlab強制修改密碼
- gitlab不同的連接方式
- jenkins相關
- 安裝部署jenkins
- python相關
- python虛擬環境
- debian安裝pyhton3.6
- Turnserver服務器搭建
- NFS相關
- 固定NFS和rsync端口
- go相關
- 安裝go
- maven相關
- debian私有倉庫搭建
- 翻墻
- linux下的百度云盤
- 私有網盤owncloud部署
- crontab定時任務
- 數據庫相關
- mongodb
- 重用操作命令
- 副本集配置文件
- 慢查詢設置
- 數據備份恢復以及數據導入導出
- 從庫允許只讀設置
- redis
- redis單節點安裝部署
- 配置文件注釋
- redis分析工具rdbtools使用
- redis數據導入導出集群工具
- redis內存信息解釋
- redis警告優化
- PHP會話session保存到redis集群
- redis啟動關閉腳本
- elk相關
- elastersearch常用命令
- elasticsearch6所需配置文件
- elasticsearch6的head插件安裝
- elk6安裝腳本
- filebeat收集php日志多行轉換
- filebeat自定義index
- elk-dockercompes配置
- docker部署elk收集runtime日志
- elasticsearch6添加新節點報錯
- elasticsearch查看索引
- docker部署es+filebeat+kibana
- mysql相關
- mysql日志
- mysql密碼過期
- mysql用戶授權訪問庫
- mysql安裝部署
- MariaDB安裝部署
- 大數據相關
- hadoop相關
- Ambari2.6離線安裝hadoop
- Ambari安裝出現的問題
- 檢測hadoop當前運行了哪些服務端口腳本
- 監控相關
- CentOS7安裝Zabbix3.4
- docker安裝zabbix
- 運維腳本
- 根據配置文件檢查服務端口運行狀態
- nginx日志分析
- ngixn日志合并腳本
- nginx查詢關鍵鏈接響應時間
- 圖片同步腳本
- 批量獲取iptables設置的端口然后驗證本機端口是否存活
- 按日期統計不同接口的響應時間
- php進程假死狀態定時清理
- 運維自動化
- deb打包命令
- ansible相關
- ansible部署
- ansible配置推送
- 編程語言
- 1-SHELL
- 2-Python
- 3-GO
- 有趣的工具
- vim
- 聲明
- 第1章: Vim解決問題的方式
- 技巧1-認識 . 命令
- 技巧2-不要自我重復
- 技巧3-以進為退
- 技巧4-執行,重復,回退
- 技巧5-查找并手動替換
- 技巧6-認識 . 范式
- 第2章: 普通模式
- 第3章: 插入模式
- 第4章: 可視模式
- 第5章: 命令行模式
- 第6章: 管理多個文件
- 第7章: 打開及保存文件
- 第8章: 用動作命令在文檔中移動
- 第9章: 在文件間跳轉
- 第10章: 復制與粘貼
- 第11章: 宏
- 第12章: 按模式匹配及按原義匹配
- 第13章: 查找
- 第14章: 替換
- 第15章: global命令
- 第16章: 通過ctags建立索引并用其瀏覽源代碼
- 第17章: 編譯代碼并通過Quickfix列表瀏覽錯誤信息
- 第18章: 通過grep,vimgrep以及其他工具對整個工程進行查找
- 第19章: 自動補全
- 第20章: 利用Vim的拼寫檢查器查找并更正拼寫錯誤
- 第21章: 接下來干什么
- 附錄A 根據個人喜好定制Vim
- 終端命令記錄回放工具
- screen使用
- iftop查看網絡流量
- dna螺旋
- shell下的俄羅斯方塊
- 正經英語
- 有意思
- 問題記錄
- python相關
- pip安裝缺少openssl和libssl
- shell相關
- debian下執行數組變量報錯
- 服務相關問題
- ububtu安裝apache2報錯
- php升級mongo拓展插件
- elk節點分片失敗
- 操作系統相關問題
- 運維記錄
- 數據庫相關
- mongo3.4安裝以及優化參數腳本
- mongodb版本升級及優化
- redis動態取消rdb保存配置
- 代理負載均衡相關
- haproxy匹配ua規則分離搜索引擎流量
- haproxy不記錄某個域名或多個域名的日志
- 其他相關
- ImageMagick升級
- NFS強制卸載掛載
- 命令相關
- curl獲取指定域名ip的狀態碼
- awk相關記錄
- rsync傳輸限速指定ssh端口
- 操作系統相關
- centos使用阿里源
- ubuntu更換國內源
- 查看操作系統版本
- 內核優化
- Centos7修改語言為英文
- debian安裝xfs格式化工具
- 查看磁盤信息
- debian的啟動管理工具
- debian安裝vmtools
- debian重啟網卡不生效的解決
- 容器虛擬化
- Docker相關
- dokcer安裝
- docker常用命令
- docker簡單腳本
- Dockerfile相關
- 帶ssh的debian鏡像
- deocker創建簡單鏡像
- 官方文檔
- docker-compose安裝
- 報錯
- docker鏡像加速
- k8s相關
- k8s常用命令
- k8s名詞解釋
- k8s相關的 yaml文件
- VM相關
- 使用VMwareWorkstation批量操作linux虛擬機
- 在windows下使用shell批量操作Vmwarworkstation
- windows下批量操作虛擬機
- ESXI相關
- vsphere網絡相關
- 小愛好
- 不方便展示