frpc_full.ini 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  1. # [common] is integral section
  2. [common]
  3. # A literal address or host name for IPv6 must be enclosed
  4. # in square brackets, as in "[::1]:80", "[ipv6-host]:http" or "[ipv6-host%zone]:80"
  5. server_addr = 0.0.0.0
  6. server_port = 7000
  7. # if you want to connect frps by http proxy or socks5 proxy, you can set http_proxy here or in global environment variables
  8. # it only works when protocol is tcp
  9. # http_proxy = http://user:passwd@192.168.1.128:8080
  10. # http_proxy = socks5://user:passwd@192.168.1.128:1080
  11. # console or real logFile path like ./frpc.log
  12. log_file = ./frpc.log
  13. # trace, debug, info, warn, error
  14. log_level = info
  15. log_max_days = 3
  16. # for authentication
  17. token = 12345678
  18. # set admin address for control frpc's action by http api such as reload
  19. admin_addr = 127.0.0.1
  20. admin_port = 7400
  21. admin_user = admin
  22. admin_pwd = admin
  23. # connections will be established in advance, default value is zero
  24. pool_count = 5
  25. # if tcp stream multiplexing is used, default is true, it must be same with frps
  26. tcp_mux = true
  27. # your proxy name will be changed to {user}.{proxy}
  28. user = your_name
  29. # decide if exit program when first login failed, otherwise continuous relogin to frps
  30. # default is true
  31. login_fail_exit = true
  32. # communication protocol used to connect to server
  33. # now it supports tcp and kcp and websocket, default is tcp
  34. protocol = tcp
  35. # specify a dns server, so frpc will use this instead of default one
  36. # dns_server = 8.8.8.8
  37. # proxy names you want to start divided by ','
  38. # default is empty, means all proxies
  39. # start = ssh,dns
  40. # heartbeat configure, it's not recommended to modify the default value
  41. # the default value of heartbeat_interval is 10 and heartbeat_timeout is 90
  42. # heartbeat_interval = 30
  43. # heartbeat_timeout = 90
  44. # 'ssh' is the unique proxy name
  45. # if user in [common] section is not empty, it will be changed to {user}.{proxy} such as 'your_name.ssh'
  46. [ssh]
  47. # tcp | udp | http | https | stcp | xtcp, default is tcp
  48. type = tcp
  49. local_ip = 127.0.0.1
  50. local_port = 22
  51. # true or false, if true, messages between frps and frpc will be encrypted, default is false
  52. use_encryption = false
  53. # if true, message will be compressed
  54. use_compression = false
  55. # remote port listen by frps
  56. remote_port = 6001
  57. # frps will load balancing connections for proxies in same group
  58. group = test_group
  59. # group should have same group key
  60. group_key = 123456
  61. # enable health check for the backend service, it support 'tcp' and 'http' now
  62. # frpc will connect local service's port to detect it's healthy status
  63. health_check_type = tcp
  64. health_check_interval_s = 10
  65. health_check_max_failed = 1
  66. health_check_timeout_s = 3
  67. [ssh_random]
  68. type = tcp
  69. local_ip = 127.0.0.1
  70. local_port = 22
  71. # if remote_port is 0, frps will assign a random port for you
  72. remote_port = 0
  73. # if you want to expose multiple ports, add 'range:' prefix to the section name
  74. # frpc will generate multiple proxies such as 'tcp_port_6010', 'tcp_port_6011' and so on.
  75. [range:tcp_port]
  76. type = tcp
  77. local_ip = 127.0.0.1
  78. local_port = 6010-6020,6022,6024-6028
  79. remote_port = 6010-6020,6022,6024-6028
  80. use_encryption = false
  81. use_compression = false
  82. [dns]
  83. type = udp
  84. local_ip = 114.114.114.114
  85. local_port = 53
  86. remote_port = 6002
  87. use_encryption = false
  88. use_compression = false
  89. [range:udp_port]
  90. type = udp
  91. local_ip = 127.0.0.1
  92. local_port = 6010-6020
  93. remote_port = 6010-6020
  94. use_encryption = false
  95. use_compression = false
  96. # Resolve your domain names to [server_addr] so you can use http://web01.yourdomain.com to browse web01 and http://web02.yourdomain.com to browse web02
  97. [web01]
  98. type = http
  99. local_ip = 127.0.0.1
  100. local_port = 80
  101. use_encryption = false
  102. use_compression = true
  103. # http username and password are safety certification for http protocol
  104. # if not set, you can access this custom_domains without certification
  105. http_user = admin
  106. http_pwd = admin
  107. # if domain for frps is frps.com, then you can access [web01] proxy by URL http://test.frps.com
  108. subdomain = web01
  109. custom_domains = web02.yourdomain.com
  110. # locations is only available for http type
  111. locations = /,/pic
  112. host_header_rewrite = example.com
  113. # params with prefix "header_" will be used to update http request headers
  114. header_X-From-Where = frp
  115. health_check_type = http
  116. # frpc will send a GET http request '/status' to local http service
  117. # http service is alive when it return 2xx http response code
  118. health_check_url = /status
  119. health_check_interval_s = 10
  120. [web02]
  121. type = https
  122. local_ip = 127.0.0.1
  123. local_port = 8000
  124. use_encryption = false
  125. use_compression = false
  126. subdomain = web01
  127. custom_domains = web02.yourdomain.com
  128. [plugin_unix_domain_socket]
  129. type = tcp
  130. remote_port = 6003
  131. # if plugin is defined, local_ip and local_port is useless
  132. # plugin will handle connections got from frps
  133. plugin = unix_domain_socket
  134. # params with prefix "plugin_" that plugin needed
  135. plugin_unix_path = /var/run/docker.sock
  136. [plugin_http_proxy]
  137. type = tcp
  138. remote_port = 6004
  139. plugin = http_proxy
  140. plugin_http_user = abc
  141. plugin_http_passwd = abc
  142. [plugin_socks5]
  143. type = tcp
  144. remote_port = 6005
  145. plugin = socks5
  146. plugin_user = abc
  147. plugin_passwd = abc
  148. [plugin_static_file]
  149. type = tcp
  150. remote_port = 6006
  151. plugin = static_file
  152. plugin_local_path = /var/www/blog
  153. plugin_strip_prefix = static
  154. plugin_http_user = abc
  155. plugin_http_passwd = abc
  156. [secret_tcp]
  157. # If the type is secret tcp, remote_port is useless
  158. # Who want to connect local port should deploy another frpc with stcp proxy and role is visitor
  159. type = stcp
  160. # sk used for authentication for visitors
  161. sk = abcdefg
  162. local_ip = 127.0.0.1
  163. local_port = 22
  164. use_encryption = false
  165. use_compression = false
  166. # user of frpc should be same in both stcp server and stcp visitor
  167. [secret_tcp_visitor]
  168. # frpc role visitor -> frps -> frpc role server
  169. role = visitor
  170. type = stcp
  171. # the server name you want to visitor
  172. server_name = secret_tcp
  173. sk = abcdefg
  174. # connect this address to visitor stcp server
  175. bind_addr = 127.0.0.1
  176. bind_port = 9000
  177. use_encryption = false
  178. use_compression = false
  179. [p2p_tcp]
  180. type = xtcp
  181. sk = abcdefg
  182. local_ip = 127.0.0.1
  183. local_port = 22
  184. use_encryption = false
  185. use_compression = false
  186. [p2p_tcp_visitor]
  187. role = visitor
  188. type = xtcp
  189. server_name = p2p_tcp
  190. sk = abcdefg
  191. bind_addr = 127.0.0.1
  192. bind_port = 9001
  193. use_encryption = false
  194. use_compression = false