TiDB 配置参数

news/2024/11/26 2:34:56/

在启动 TiDB 时,你可以使用命令行参数或环境变量来配置 TiDB。

要快速了解 TiDB 的参数体系与参数作用域,建议先观看下面的培训视频(时长 17 分钟)。

本文将详细介绍 TiDB 的命令行启动参数。TiDB 的默认端口为 4000(客户端请求)与 10080(状态报告)。

--advertise-address

  • 登录 TiDB 的 IP 地址
  • 默认:""
  • 必须确保用户和集群中的其他机器都能够访问到该 IP 地址

--config

  • 配置文件
  • 默认:""
  • 如果你指定了配置文件,TiDB 会首先读取配置文件的配置。如果对应的配置在命令行参数里面也存在,TiDB 就会使用命令行参数的配置来覆盖配置文件中的配置。详细的配置项请参阅 TiDB 配置文件描述。

--config-check

  • 检查配置文件的有效性并退出
  • 默认:false

--config-strict

  • 增强配置文件的有效性
  • 默认:false

--cors

  • 用于设置 TiDB HTTP 状态服务的 Access-Control-Allow-Origin
  • 默认:""

--host

  • TiDB 服务监听的 host
  • 默认:"0.0.0.0"
  • 0.0.0.0 默认会监听所有的网卡地址。如果有多块网卡,可以指定对外提供服务的网卡,如 192.168.100.113

--enable-binlog

  • 是否产生 TiDB Binlog
  • 默认:false

-L

  • Log 级别
  • 默认:"info"
  • 可选:"debug","info","warn","error","fatal"

--lease

  • Schema lease 的持续时间。除非你知道更改该值带来的后果,否则你的更改操作是危险的
  • 默认:45s

--log-file

  • Log 文件
  • 默认:""
  • 如果未设置该参数,log 会默认输出到 "stderr";如果设置了该参数,log 会输出到对应的文件中。

--log-slow-query

  • 慢查询日志文件路径
  • 默认:""
  • 如果未设置该参数,log 会默认输出到 --log-file 指定的文件中

--metrics-addr

  • Prometheus Pushgateway 地址
  • 默认:""
  • 如果该参数为空,TiDB 不会将统计信息推送给 Pushgateway。参数格式示例:--metrics-addr=192.168.100.115:9091

--metrics-interval

  • 推送统计信息到 Prometheus Pushgateway 的时间间隔
  • 默认:15s
  • 设置为 0 表示不推送统计信息给 Pushgateway。示例:--metrics-interval=2 指每两秒推送到 Pushgateway

-P

  • TiDB 服务监听端口
  • 默认:"4000"
  • TiDB 服务会使用该端口接受 MySQL 客户端发来的请求

--path

  • 对于本地存储引擎 "unistore" 来说,path 指定的是实际的数据存放路径
  • 当 --store = tikv 时,必须指定 path;当 --store = unistore 时,如果不指定 path,会使用默认值。
  • 对于 "TiKV" 存储引擎来说,path 指定的是实际的 PD 地址。假如在 192.168.100.113:2379、192.168.100.114:2379 和 192.168.100.115:2379 上面部署了 PD,那么 path 为 "192.168.100.113:2379, 192.168.100.114:2379, 192.168.100.115:2379"
  • 默认:"/tmp/tidb"
  • 可以通过 tidb-server --store=unistore --path="" 来启动一个纯内存引擎的 TiDB

--proxy-protocol-networks

  • 允许使用 PROXY 协议连接 TiDB 的代理服务器地址列表。
  • 默认:""
  • 通常情况下,通过反向代理使用 TiDB 时,TiDB 会将反向代理服务器的 IP 地址视为客户端 IP 地址。对于支持 PROXY 协议的反向代理(如 HAProxy),开启 PROXY 协议后能让反向代理透传客户端真实的 IP 地址给 TiDB。
  • 配置该参数后,TiDB 将允许配置的源 IP 地址使用 PROXY 协议连接到 TiDB,且拒绝这些源 IP 地址使用非 PROXY 协议连接。若该参数为空,则任何源 IP 地址都不能使用 PROXY 协议连接到 TiDB。地址可以使用 IP 地址格式 (192.168.1.50) 或者 CIDR 格式 (192.168.1.0/24),并可用 , 分隔多个地址,或用 * 代表所有 IP 地址。

警告

需谨慎使用 * 符号,因为它可能引入安全风险,允许来自任何 IP 的客户端自行汇报其 IP 地址。另外,它可能会导致部分直接连接 TiDB 的内部组件无法使用,例如 TiDB Dashboard。

--proxy-protocol-header-timeout

  • PROXY Protocol 请求头读取超时时间
  • 默认:5
  • 单位:秒

注意

不要将该参数配置为 0。除非特殊情况,一般使用默认值即可。

--report-status

  • 用于打开或者关闭服务状态监听端口
  • 默认:true
  • 将参数值设置为 true 表明开启状态监听端口;设置为 false 表明关闭状态监听端口

--run-ddl

  • tidb-server 是否运行 DDL 语句,集群内至少需要有一台 tidb-server 设置该参数
  • 默认:true
  • 值可以为 true 或者 false。设置为 true 表明自身会运行 DDL;设置为 false 表明自身不会运行 DDL

--socket string

  • TiDB 服务使用 unix socket file 方式接受外部连接
  • 默认:""
  • 例如可以使用 "/tmp/tidb.sock" 来打开 unix socket file

--status

  • TiDB 服务状态监听端口
  • 默认:"10080"
  • 该端口用于展示 TiDB 内部数据,包括 prometheus 统计和 pprof
  • Prometheus 统计可以通过 http://host:status_port/metrics 访问
  • pprof 数据可以通过 http://host:status_port/debug/pprof 访问

--status-host

  • TiDB 服务状态监听 host
  • 默认:"0.0.0.0"

--store

  • 用来指定 TiDB 底层使用的存储引擎
  • 默认:"unistore"
  • 可以选择 "unistore"(本地存储引擎)或者 "tikv"(分布式存储引擎)

--token-limit

  • TiDB 中同时允许运行的 Session 数量,用于流量控制
  • 默认:1000
  • 如果当前运行的连接多于该 token-limit,那么请求会阻塞,等待已经完成的操作释放 Token

-V

  • 输出 TiDB 的版本
  • 默认:""

--plugin-dir

  • plugin 存放目录
  • 默认:"/data/deploy/plugin"

--plugin-load

  • 需要加载的 plugin 名称,多个 plugin 以 "," 逗号分隔
  • 默认:""

--affinity-cpus

  • 设置 TiDB server CPU 亲和性,以 "," 逗号分隔,例如 "1,2,3"
  • 默认:""

--repair-mode

  • 是否开启修复模式,仅用于数据修复场景
  • 默认:false

--repair-list

  • 修复模式下需要修复的表名
  • 默认:""

http://www.ppmy.cn/news/334489.html

相关文章

uni-app 官网教程

官网:https://uniapp.dcloud.net.cn/ github :https://github.com/dcloudio/uni-app uni-app 入门教程:https://www.5axxw.com/wiki/content/41fkvm ​uniapp 可视化开发 --- 前端开发工具、组件库集合:https://blog.csdn.net/w…

uni-app下载和使用

是什么? uni-app是一个使用vue.js开发所有前端应用的框架,开发者编写一套代码,可以发布到ios,Android,web,以及各种小程序(微信/支付宝/百度/头条/飞书/QQ/快手),快手多个…

uni-app之uniCloud(一)

uni-app ( https://uniapp.dcloud.io/README ) qq:1254845399 是一个使用vue.js 开发所有前端应用的框架,开发者编写一套代码,可发布到iOS、Android、Web(响应式)、以及各种小程序(微信/支付宝/百…

unipp

在H5上正常运行,在app打包测试或者真机测试会出现白屏问题,这个时候需要配置基础路径 uniapp图片显示需注意问题 text标签为文本标签,如果在text标签内写图片,会出现图片无法正常展示 uniapp设置多端兼容 // #ifdef H5 //在H5…

python基本语法知识(四)——包和模块

模块 例子1:导入某个模块中的具体功能 # 只导入time模块中的sleep方法,可以直接使用sleep调用不用加time. from time import sleep print("hello") sleep(500) print("fine")# 只导入time模块中的sleep方法,并给sleep起别名为sl f…

uni-app②

文章目录 二、微信小程序简介(一)文档相关开发者工具使用小程序代码构成小程序基本操作 三、uniapp 开发规范uniapp 开发环境开发工具下载 HBuilderX 工程搭建项目运行浏览器运行 四、组件基础组件基础组件列表组件公共属性集合 扩展组件自定义组件 UNI-…

uniCloud

前言 一个云开发平台, 用熟悉的js,轻松搞定前后台整体业务 uni-app官网 核心知识点:客户端与服务空间是怎样工作的 创建一个uniCloud 项目 --- studyUniCloud 创建&关联服务空间 至此,studyUniCloud 已经拥有一个云开发平台&#xff0c…

uni-app ①

文章目录 一、uni-app简介学习 uniapp 本质uniapp 优势uni-app 和 vue 的关系uni-app 和小程序有什么关系uniapp 与 web 代码编写区别课程内容学习重点知识点 一、uni-app 简介 uni-app 是一个使用 Vue.js 进行 开发所有前端应用的框架。开发者编写一套代码,即可发…