clickhouse 无法远程连接

lsof 命令

lsof 命令用来从系统获得与网络连接相关的信息,全称为 “列出打开文件(lists openfiles)”。这是因为,在Unix中的一切(包括网络套接字)都是文件。
在这里插入图片描述
lsof -i 用来查看当前IPv4或IPv6的任务
lsof -i :<端口号> 用来查看指定端口的套接字线程(注意:冒号的右边不能有空格,左边随意)
在这里插入图片描述
从上面可以看到 clickhouse 默认只监听本地的8123端口。所以,在本地使用 /usr/bin/clickhouse-client --host localhost --port 8123 可以连接成功。但在外部就无法访问了(我这里 clickhouse 装在虚拟机上,外部主机使用 dbeaver 连接)

修改配置文件

查看 clickhouse-server 的配置文件 ls /etc/clickhouse-server ,以下两个文件待修改

  • config.xml
  • users.xml
    在这里插入图片描述

vim 编辑器基础

/<关键词> 在文档中搜索关键词,并高亮显示。按 “回车”,光标聚焦到关键词处,按 “n” 键,搜索下一个
i 进入编辑模式
Esc 退出当前模式
:wq 保存并退出
:q! 强制退出(对于只读文件,必须加感叹号强制执行)
:wq! 强制保存退出(对于只读文件,必须加感叹号强制执行)

config.xml

vim /etc/clickhouse-server/config.xml
取消 <listen_host>::</listen_host> 的注释,这个表示监听来自任意IP地址的连接
在这里插入图片描述

users.xml

vim /etc/clickhouse-server/users.xml
确保来自任意IP地址的连接都能访问

<networks>
	<ip>::/0</ip>
</networks>

在这里插入图片描述

重新启动

/etc/init.d/clickhouse-server stop
/etc/init.d/clickhouse-server start
# 或
/etc/init.d/clickhouse-server restart

# 查看 clickhouse-server 状态
/etc/init.d/clickhouse-server status

在这里插入图片描述
再使用 lsof -i :8123 查看状态,可以发现地址由 localhost 变为 * 了。
在这里插入图片描述

连接clickhouse

使用开源的 dbeaver 连接 clickhouse的8123端口,可以看到,现在已经可以连上了
在这里插入图片描述

  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
以下是使用Docker安装ClickHouse并配置远程访问的步骤: 1. 首先,确保已经安装了Docker。如果没有安装,请根据您的操作系统进行安装。 2. 打开终端或命令提示符,并运行以下命令来拉取ClickHouse的Docker镜像: ```shell docker pull yandex/clickhouse-server ``` 3. 运行以下命令来创建并启动一个ClickHouse容器: ```shell docker run -d --name clickhouse-server -p 8123:8123 -p 9000:9000 yandex/clickhouse-server ``` 这将创建一个名为clickhouse-server的容器,并将ClickHouse的HTTP端口映射到主机的8123端口,将ClickHouse的TCP端口映射到主机的9000端口。 4. 确认容器已经成功启动。运行以下命令来查看容器的状态: ```shell docker ps ``` 您应该能够看到clickhouse-server容器正在运行。 5. 现在,您可以通过访问http://localhost:8123来访问ClickHouse的Web界面。在Web界面中,您可以执行SQL查询和其他操作。 6. 要配置远程访问,您需要编辑ClickHouse的配置文件。运行以下命令进入ClickHouse容器的bash终端: ```shell docker exec -it clickhouse-server bash ``` 7. 在容器中,找到ClickHouse的配置文件,并使用文本编辑器进行编辑。默认情况下,配置文件位于/etc/clickhouse-server/config.xml。您可以运行以下命令来编辑配置文件: ```shell vi /etc/clickhouse-server/config.xml ``` 8. 在配置文件中,找到以下行: ```xml <listen_host>::</listen_host> ``` 将其修改为: ```xml <listen_host>0.0.0.0</listen_host> ``` 这将允许ClickHouse接受来自任何IP地址的连接。 9. 保存并关闭配置文件。 10. 重新启动ClickHouse容器,以使配置更改生效: ```shell docker restart clickhouse-server ``` 现在,您应该能够通过使用ClickHouse的IP地址和端口号来远程访问ClickHouse数据库。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值