热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

shmysqllogin_MysqlShell免密登录的思考及实际应用案例

前言数据库图形化工具的出现,给我们操作数据库带来了许多便利,但是过度的依赖工具,始终无法明白其内部的一些原理,离开了工具&#

前言

数据库图形化工具的出现,给我们操作数据库带来了许多便利,但是过度的依赖工具,始终无法明白其内部 的一些原理,离开了工具,可能寸步难行,所以尽量使用原生的命令行来操作数据库,可以增加熟练度,提高我们知识的深度。

最常见的明文登录方式

以下mysql命令参数,相信大家已经是耳熟能详了:

-h参数指定mysql主机。-u指定mysql用户。-P(大写)指定端口。-p(小写)指定密码。这里衍生出两个问题:

1)每次使用都需要指定一长串的参数和密码。

2)密码直接在命令行暴露出来,运行时,在一个短暂的时间间隔内,是可以直接通过ps命令查看到你数据库的密码的,所以十分不安全。

当然你可以不用指定密码参数,而是选择手动输入。

明文配置文件的方式登录

如果你不想在控制台,以交互的方式输入密码,那还有一种方式,将明文密码写入到文件中。

3d26a11f460cd4dd31c38cff813ca3e5.png

当然也可以试试验证读取配置情况:

mysql --defaults-file=./A.cnf --print-defaults

这里打印的意思是:mysql将会使用如下的参数进行登录连接。

小结

总结来说:指定明文密码的两种方式是:

1)通过指定--password (-p) 交互式的输入密码。

2)将密码放在一个配置 文件中。

当我们使用一些数据库的shell脚本时,当然不能这样交互式的输入密码,并且我们也不想把密码暴露到配置文件中,那该怎么做呢?

学习mysql命令的参数配置项

不知道如何实现,我们首先来熟悉熟悉mysql命令提供的参数。默认情况下,mysql会按如下顺序读取配置:

1) /etc/my.cnf

2)/etc/mysql/my.cnf

3)~/.my.cnf

参数:

--no-defaults ,不读取配置文件中的任何内容。但是mylogin.cnf除外。--login-path,指定在mysqlconfigeditor中设置选项组名称。--print-defaults,打印从参数配置文件中获得的所有选项。密码值会被屏蔽。了解了上述的基本参数作用后,我们来学习,如何保护我们的密码。

使用mysqlconfigeditor存储登录信息

mysqlconfigeditor是一个存储mysql登录信息的工具,它会将你的身份认证信息存储到一个名为 .mylogin.cnf 的登录路径文件中。

由于该文件是隐藏文件,你可以用如下命令查看:

ls -l .mylogin.cnf 文件的内容是进行了混淆加密的,明文方式它存储的文件内容大概是:

[pathA]user = aaapassword = aaapwdhost = ip1[pathB]user = rootpassword = pwd2host = ip2这里,可以有多组配置,每一个用括号包裹的块,我们称它为选项组,每个选项组内容包括:主机、用户、密码、端口、套接字等信息。

当调用Mysql客户端命令连接到服务器时,客户端将mylogin.cnf与其他指定的参数配置文件一起使用。这里的优先级高于其他文件,但低于在客户端命令行上显式指定的配置。

6583cfefb9d9cf2e3c1994f55d7d3f04.png

当然啦,我们也可以显示的指定用那个选项组,就像是使用A计划还是B计划一样。默认mysql会执行[client] 和 [mysql] 选项组配置。

将密码放入受保护的文件

要查看mysqlconfigeditor写入.mylogin.cnf文件的内容,我们可以使用如下命令:

mysql_config_editor print --allmysql_config_editor print --login-path=pathA登录路径文件必须对当前用户是可读和可写的,而对其他用户是不可访问的。否则,mysqlconfigeditor将忽略它,客户机程序也不会使用它,一个完整的设置命令入下:

mysql_config_editor set --login-path=pathA \--host=localhost --user=root --password --port=3306 \--socket=~/pathA_mysql.sock

操作帮助说明可以通过执行如下命令查看:

mysql_config_editor set --help其中--socket指定mysql以socket方式运行的sock文件位置。--password 指定需要密码,这里会在回车后让你输入密文。它默认在数据存储到内容中,并且,我们使用print打印的时候,它同样也不会显示明文,是不是安全多了呢。

5928f5525a2285e9eb9ac69524b3bfd5.png

登录命令变成:

mysql --login-path=pathA

实际案例应用

完成上述配置后,我们可以愉快的使用密文登录mysql啦。这里提供一个实际的案例。

要求:编写crontab定时任务,定时的清理mysql A表一天前的数据,每天早上6点执行,需要提供日志记录显示执行状态。

小试牛刀

上面我们已经配置好了免密登录,下面来试试执行一条sql语句。

mysql --login-path=pathA -e 'select 1'

2595e12e65e2b68949eb7e59be609a41.png

获取今天凌晨的毫秒值:

select UNIX_TIMESTAMP(CAST(SYSDATE()AS DATE)) * 1000没有任何问题,按照要求,我们编写带记录日志的shell脚本,参考如下:

#!/bin/sh# adirname - return 绝对路径adirname() { odir=`pwd`; cd `dirname $1`; pwd; cd "${odir}"; }MYNAM=`basename "$0"`MYDIR=`adirname "$0"`MYHOME="/home/appuser"MYLOG_PATH="${MYHOME}/logs"MYLOG="${MYLOG_PATH}/${MYNAM}_`date +%F`.log"if [ ! -f "$MYLOG" ]; then touch "$MYLOG"fi# 记录日志function loginfo(){ echo "$1" echo "$(date -d today +"%Y%m%d %H:%M:%S") - $1" >> ${MYLOG} 2>> ${MYLOG}}mysql --login-path=pathA -e 'delete from A where time

#每天6点执行0 6 * * * /bin/sh /home/root/del_tabl_task.sh

总结

本文对比介绍了 明文密码登录mysql的两种方式和密文登录。希望你了解如下知识点:1、mysqlconfigeditor工具的用法及作用?

2、mysql shell脚本的简单使用?

3、crontab定时任务脚本的配置使用。

4、如何在shell中记录输出日志到文件。

当然这些知识可能都只是冰山一角,希望对你有所启发。

为了方便大家学习讨论,我创建了一个java疑难攻坚互助大家庭,和其他传统的学习交流不同。本群主要致力于解决项目中的疑难问题,在遇到项目难以解决的问题时,都可以在这个大家庭里寻求帮助。

公众关号注侠梦的开发笔记后回复【问题的答案】进入:java中Integer包装类的基本数据类型是?如果你也经历过遇到项目难题,无从下手,他人有可能可以给你提供一些思路和看法,一百个人就有一百种思路,同样,如果你也乐于帮助别人,那解决别人遇到的问题,也同样对你是一种锻炼。

自学路上你不孤单,欢迎来公众号【侠梦的开发笔记】,回复干货,为你准备了精选的学习视频



推荐阅读
  • PHP中元素的计量单位是什么? ... [详细]
  • 在CentOS上部署和配置FreeSWITCH
    在CentOS系统上部署和配置FreeSWITCH的过程涉及多个步骤。本文详细介绍了从源代码安装FreeSWITCH的方法,包括必要的依赖项安装、编译和配置过程。此外,还提供了常见的配置选项和故障排除技巧,帮助用户顺利完成部署并确保系统的稳定运行。 ... [详细]
  • 作为140字符的开创者,Twitter看似简单却异常复杂。其简洁之处在于仅用140个字符就能实现信息的高效传播,甚至在多次全球性事件中超越传统媒体的速度。然而,为了支持2亿用户的高效使用,其背后的技术架构和系统设计则极为复杂,涉及高并发处理、数据存储和实时传输等多个技术挑战。 ... [详细]
  • 智能制造数据综合分析与应用解决方案
    在智能制造领域,生产数据通过先进的采集设备收集,并利用时序数据库或关系型数据库进行高效存储。这些数据经过处理后,通过可视化数据大屏呈现,为生产车间、生产控制中心以及管理层提供实时、精准的信息支持,助力不同应用场景下的决策优化和效率提升。 ... [详细]
  • HBase在金融大数据迁移中的应用与挑战
    随着最后一台设备的下线,标志着超过10PB的HBase数据迁移项目顺利完成。目前,新的集群已在新机房稳定运行超过两个月,监控数据显示,新集群的查询响应时间显著降低,系统稳定性大幅提升。此外,数据消费的波动也变得更加平滑,整体性能得到了显著优化。 ... [详细]
  • Spring Security 认证模块的项目构建与初始化
    本文详细介绍了如何构建和初始化Spring Security认证模块的项目。首先,通过创建一个分布式Maven聚合工程,该工程包含四个模块,分别为core、browser(用于演示)、app等,以构成完整的SeehopeSecurity项目。在项目构建过程中,还涉及日志生成机制,确保能够输出关键信息,便于调试和监控。 ... [详细]
  • 如何在Linux系统中利用crontab定时执行Shell脚本任务?
    在Linux系统中,如何实现定时执行任务脚本?在服务器日常运维过程中,经常需要定期执行某些任务,例如数据库备份、日志文件切割等。通过使用crontab工具,可以轻松配置这些周期性任务,确保它们按时自动运行,提高系统管理效率和可靠性。 ... [详细]
  • 本文推荐了六款高效的Java Web应用开发工具,并详细介绍了它们的实用功能。其中,分布式敏捷开发系统架构“zheng”项目,基于Spring、Spring MVC和MyBatis技术栈,提供了完整的分布式敏捷开发解决方案,支持快速构建高性能的企业级应用。此外,该工具还集成了多种中间件和服务,进一步提升了开发效率和系统的可维护性。 ... [详细]
  • Spring Boot 实战(一):基础的CRUD操作详解
    在《Spring Boot 实战(一)》中,详细介绍了基础的CRUD操作,涵盖创建、读取、更新和删除等核心功能,适合初学者快速掌握Spring Boot框架的应用开发技巧。 ... [详细]
  • 结语 | 《探索二进制世界:软件安全与逆向分析》读书笔记:深入理解二进制代码的逆向工程方法
    结语 | 《探索二进制世界:软件安全与逆向分析》读书笔记:深入理解二进制代码的逆向工程方法 ... [详细]
  • 本文详细介绍了使用响应文件在静默模式下安装和配置Oracle 11g的方法。硬件要求包括:内存至少1GB,具体可通过命令`grep -i memtotal /proc/meminfo`进行检查。此外,还提供了详细的步骤和注意事项,确保安装过程顺利进行。 ... [详细]
  • 从无到有,构建个人专属的操作系统解决方案
    操作系统(OS)被誉为程序员的三大浪漫之一,常被比喻为计算机的灵魂、大脑、内核和基石,其重要性不言而喻。本文将详细介绍如何从零开始构建个人专属的操作系统解决方案,涵盖从需求分析到系统设计、开发与测试的全过程,帮助读者深入理解操作系统的本质与实现方法。 ... [详细]
  • 本题库精选了Java核心知识点的练习题,旨在帮助学习者巩固和检验对Java理论基础的掌握。其中,选择题部分涵盖了访问控制权限等关键概念,例如,Java语言中仅允许子类或同一包内的类访问的访问权限为protected。此外,题库还包括其他重要知识点,如异常处理、多线程、集合框架等,全面覆盖Java编程的核心内容。 ... [详细]
  • ylbtech-进销存管理解决方案:进销存管理,即购销链管理,涵盖企业从采购(进)、库存(存)到销售(销)的全流程动态管控。其中,“进”涉及从市场询价、供应商选择、采购执行直至货物入库及支付流程;“销”则包括产品定价、客户报价、订单处理及销售出库等环节。该解决方案旨在通过信息化手段,提升企业运营效率,优化库存结构,增强市场响应速度。 ... [详细]
  • 本文深入探讨了数据库性能优化与管理策略,通过实例分析和理论研究,详细阐述了如何有效提升数据库系统的响应速度和处理能力。文章首先介绍了数据库性能优化的基本原则和常用技术,包括索引优化、查询优化和存储管理等。接着,结合实际应用场景,讨论了如何利用容器化技术(如Docker)来部署和管理数据库,以提高系统的可扩展性和稳定性。最后,文章还提供了具体的配置示例和最佳实践,帮助读者在实际工作中更好地应用这些策略。 ... [详细]
author-avatar
月星名店_882
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有