MySQL有关1042 Can’t get hostname for your address的问题分析解决过程

本文解决了一个常见的MySQL远程连接问题,即遇到1042-Can’t get hostname for your address错误的情况。通过调整skip-name-resolve参数和hostname设置,可以有效解决因DNS解析问题导致的权限验证失败,确保远程连接正常。

[Comment 1]
 前同事企鹅上面说他安装的mysql 5.5,发现用mysql客户端远程连接的时候,报1042-Can’t get hostname for your address错误,但是权限已经grant了并且grant成功了。
 这个报错的意思是“您的地址无法获得主机名”,我就想到了skip-name-resolve参数。

官方文档:

  • --skip-name-resolve

    Use IP addresses rather than host names when creating grant table entries. This option can be useful if your DNS does not work.

     

  • --skip-name-resolve

    Do not resolve host names when checking client connections. Use only IP numbers. If you use this option, allHost column values in the grant tables must be IP numbers orlocalhost. See Section 7.7.11, “How MySQL Uses DNS”.

     

    mysql> show variables like '%skip_name_resolve%';
    +-------------------+-------+
    | Variable_name     | Value |
    +-------------------+-------+
    | skip_name_resolve | ON   |
    +-------------------+-------+
    1 row in set (0.00 sec)

    mysql> set global skip_name_resolve=0;
    ERROR 1238 (HY000): Variable 'skip_name_resolve' is a read only variable
    mysql>
    失败了,看来是只有修改my.cnf了

     

    在[mysqld]节点下修改

    skip-name-resolve
    #忽略主机名的方式访问
    lower_case_table_names=1
    #忽略数据库表名大小写

    重启MySQLD process即可。

     


    [Comment 2]
    前同事企鹅留言:
    mysql -h 192.168.1.101 -u root -p
    访问不了,我本地的mysql.192.168.1.101是本地ip地址。
    grant all privileges on *.* to 'hive'@'192.168.1.101' identified by 'hive' with grant option;就是报连接不上,权限问题,怎么搞定。

    查看官方文档:

  • hostname

    Variable Namehostname
    Variable ScopeGlobal
    Dynamic VariableNo
     Permitted Values
    Typestring

    The server sets this variable to the server host name at startup.

     

    mysql> show variables like '%hostname%';
    +---------------+-------------------------------------------+
    | Variable_name | Value                                     |
    +---------------+-------------------------------------------+
    | hostname      | xxxxx.china.online.xx.com |
    +---------------+-------------------------------------------+
    1 row in set (0.00 sec)
    
    mysql> set global hostname='xxxxx2.china.online.xx.com';
    ERROR 1238 (HY000): Variable 'hostname' is a read only variable
    mysql> 

    失败了,只有修改my.cnf了,在mysqld选项下面

     

    [mysqld]
    # 注释掉参数即可,mysql直接用本机ip不能访问
    # hostname

    然后重启mysqld 服务即可。

     

     

### 安装 TensorFlow-GPU 2.6 版本于 Ubuntu 20.04 的指导 #### 准备工作 确保系统已更新至最新状态并安装必要的依赖包。 ```bash sudo apt update && sudo apt upgrade -y sudo apt install -y software-properties-common ``` #### NVIDIA 驱动程序安装 为了使 GPU 加速功能正常运作,需先安装兼容的 NVIDIA 显卡驱动。对于 TensorFlow-GPU 2.6, 推荐使用 CUDA Toolkit 11.2 和 cuDNN SDK 8.1[^2]。 - 添加 NVIDIA 软件仓库: ```bash distribution=$(. /etc/os-release;echo $ID$VERSION_ID) wget https://developer.download.nvidia.com/compute/cuda/repos/$distribution/x86_64/cuda-$distribution.pin sudo mv cuda-$distribution.pin /etc/apt/preferences.d/cuda-repository-pin-600 sudo apt-key adv --fetch-keys https://developer.download.nvidia.com/compute/cuda/repos/$distribution/x86_64/7fa2af80.pub sudo add-apt-repository "deb http://developer.download.nvidia.com/compute/cuda/repos/$distribution/x86_64/ /" ``` - 安装特定版本的显卡驱动与工具链: ```bash sudo apt-get update sudo apt-get -y install cuda-drivers=460.* sudo apt-get -y install cuda-toolkit-11-2 ``` #### Anaconda 环境配置 建议通过 Anaconda 创建独立 Python 环境来管理软件包及其依赖关系。 - 下载 Miniconda 或 Anaconda 并按照官方说明完成安装过程。 - 启动新环境用于 TensorFlow 开发: ```bash conda create --name tf_gpu python=3.8 conda activate tf_gpu ``` #### TensorFlow 及其依赖项部署 在激活环境中执行如下命令以获取所需库文件。 ```bash pip install tensorflow==2.6.0 pip install nvidia-cudnn-cu11==8.1.0.77 ``` 验证安装成功与否可通过运行简单测试脚本来确认。 ```python import tensorflow as tf print("Num GPUs Available: ", len(tf.config.experimental.list_physical_devices('GPU'))) ``` 如果一切顺利,则会显示可用 GPU 数量;否则可能需要排查路径设置等问题。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值