MySQL数据库的实际配置技巧简介
以下的文章主要介绍的是MySQL数据库的实际配置技巧,我们大家都知道用root的相关用户启动的远程服务,其一直是个安全大忌,主要原因是如果相关的服务程序出现一些问题,远程攻击者极有可能获得主机的完全控制权。 MySQL(和PHP搭配之最佳组合)从3.23.15版 本
以下的文章主要介绍的是MySQL数据库的实际配置技巧,我们大家都知道用root的相关用户启动的远程服务,其一直是个安全大忌,主要原因是如果相关的服务程序出现一些问题,远程攻击者极有可能获得主机的完全控制权。
MySQL(和PHP搭配之最佳组合)从3.23.15版
本开始时作了小小的改动,默认安装后服务要用MySQL(和PHP搭配之最佳组合)用户来启动,不允许root用户启动。如果非要用root用户来启动,必须加上--user=root
的参数(./safe_MySQL(和PHP搭配之最佳组合)d --user=root &)。因为MySQL(和PHP搭配之最佳组合)中有LOAD DATA INFILE和SELECT ... INTO OUTFILE的SQL语句,如果是root用户启动了
MySQL(和PHP搭配之最佳组合)服务器,那么,MySQL数据库用户就拥有了root用户的写权限。不过MySQL(和PHP搭配之最佳组合)还是做了一些限制的,比如LOAD DATA INFILE只能读全局可读的文件
,SELECT ... INTO OUTFILE不能覆盖已经存在的文件。
本地的日志文件也不能忽视,包括shell的日志和MySQL(和PHP搭配之最佳组合)自己的日志。有些用户在本地登陆或备份MySQL数据库的时候为了图方便,有时会在命令行参
数里直接带了数据库的密码,如:
shell>/usr/local/MySQL(和PHP搭配之最佳组合)/bin/MySQL(和PHP搭配之最佳组合)dump -uroot -ptest test>test.sql
shell>/usr/local/MySQL(和PHP搭配之最佳组合)/bin/MySQL(和PHP搭配之最佳组合) -uroot -ptest
这些命令会被shell记录在历史文件里,比如bash会写入用户目录的.bash_history文件,如果这些文件不慎被读,那么数据库的密码就会泄漏
。用户登陆数据库后执行的SQL命令也会被MySQL(和PHP搭配之最佳组合)记录在用户目录的.MySQL(和PHP搭配之最佳组合)_history文件里。如果MySQL数据库用户用SQL语句修改了数据库密码,也会
因.MySQL(和PHP搭配之最佳组合)_history文件而泄漏。所以我们在shell登陆及备份的时候不要在-p后直接加密码,而是在提示后再输入MySQL数据库密码。
另外这两个文件我们也应该不让它记录我们的操作,以防万一。
shell>rm .bash_history .MySQL(和PHP搭配之最佳组合)_history
shell>ln -s /dev/null .bash_history
shell>ln -s /dev/null .MySQL(和PHP搭配之最佳组合)_history
上门这两条命令把这两个文件链接到/dev/null,那么我们的操作就不会被记录到这两个文件里了。
编程需要注意的一些问题
不管是用哪种程序语言写连接MySQL(和PHP搭配之最佳组合)MySQL数据库的程序,有一条准则是永远不要相信用户提交的数据!
对于数字字段,我们要使用查询语句:SELECT * FROM table WHERE ID='234',不要使用SELECT * FROM table WHERE ID=234这样的查询语句
。MySQL(和PHP搭配之最佳组合)会自动把字串转换为数字字符并且去除非数字字符。如果用户提交的数据经过了MySQL(和PHP搭配之最佳组合)_escape_string处理,这样我们就可以完全杜绝
各种编程语言该注意的问题:
1)所有Web程序:
a)尝试在Web表单输入单引号和双引号来测试可能出现的错误,并找出原因所在。
b)修改URL参数带的%22 ('"'), %23 ('#'), 和 %27 (''')。
c)对于数字字段的变量,我们的应用程序必须进行严格的检查,否则是非常危险的。
d)检查用户提交的数据是否超过字段的长度。
e)不要给自己程序连接MySQL数据库的用户过多的访问权限。
2)PHP:
a)检查用户提交的数据在查询之前是否经过addslashes处理,在PHP 4.0.3以后提供了基于MySQL(和PHP搭配之最佳组合) C API的函数MySQL(和PHP搭配之最佳组合)_escape_string()。
3)MySQL(和PHP搭配之最佳组合) C API:
a)检查查询字串是否用了MySQL(和PHP搭配之最佳组合)_escape_string() API调用。
4)MySQL(和PHP搭配之最佳组合)++:
a)检查查询字串是否用了escape和quote处理。
5)Perl DBI:
a)检查查询字串是否用了quote()方法。
6)Java JDBC:
a)检查查询字串是否用了PreparedStatement对象。
一些小窍门
1)如果不慎忘记了MySQL(和PHP搭配之最佳组合)的root密码,我们可以在启动MySQL(和PHP搭配之最佳组合)服务器时加上参数--skip-grant-tables来跳过授权表的验证 (./safe_MySQL(和PHP搭配之最佳组合)d
--skip-grant-tables &),这样我们就可以直接登陆MySQL(和PHP搭配之最佳组合)服务器,然后再修改root用户的口令,重启MySQL(和PHP搭配之最佳组合)就可以用新口令登陆了。
2)启动MySQL(和PHP搭配之最佳组合)服务器时加上--skip-show-database使一般数据库用户不能浏览其它MySQL数据库。
3)启动MySQL(和PHP搭配之最佳组合)服务器时加上--chroot=path参数,让MySQL(和PHP搭配之最佳组合)d守护进程运行在chroot环境中。这样SQL语句LOAD DATA INFILE和SELECT ... INTO
OUTFILE就限定在chroot_path下读写文件了。这里有一点要注意,MySQL(和PHP搭配之最佳组合)启动后会建立一个MySQL(和PHP搭配之最佳组合).sock文件,默认是在/tmp目录下。使用了
chroot后,MySQL(和PHP搭配之最佳组合)会在chroot_path/tmp去建立MySQL(和PHP搭配之最佳组合).sock文件,如果没有chroot_path/tmp目录或启动MySQL(和PHP搭配之最佳组合)的用户没有这个目录写权限就不能
建立MySQL(和PHP搭配之最佳组合).sock文件,MySQL(和PHP搭配之最佳组合)会启动失败。比如我们加了--chroot=/usr/local/MySQL(和PHP搭配之最佳组合)/启动参数,那么最好建立一个启动MySQL(和PHP搭配之最佳组合)的用户能写的
/usr/local/MySQL(和PHP搭配之最佳组合)/tmp目录,当然我们也可以用--socket=path来指定MySQL(和PHP搭配之最佳组合).sock文件的路径,但这个path一定要在chroot_path里面。
4)启动MySQL(和PHP搭配之最佳组合)服务器时加上--log-slow-queries[=file]参数,这样MySQL(和PHP搭配之最佳组合)d会把SQL命令执行时间超过long_query_time的写入file文件。如果没
有指定=file,MySQL(和PHP搭配之最佳组合)d默认会写到数据目录下的hostname-slow.log。如果只指定了filename,没有指定路径,那么MySQL(和PHP搭配之最佳组合)d也会把filename写到
数据目录下。我们通过这个日志文件可以找出执行时间超长的查询语句,然后尽可能的优化它减轻MySQL(和PHP搭配之最佳组合)服务器的负担。
5)如果我们只需本机使用MySQL(和PHP搭配之最佳组合)服务,那么我们还可以加上--skip-networking启动参数使MySQL(和PHP搭配之最佳组合)不监听任何TCP/IP连接,增加安全性
以上的相关内容就是对MySQL数据库配置技巧的介绍,望你能有所收获。

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Membuat sandaran dan memulihkan pangkalan data MySQL dalam PHP boleh dicapai dengan mengikuti langkah berikut: Sandarkan pangkalan data: Gunakan arahan mysqldump untuk membuang pangkalan data ke dalam fail SQL. Pulihkan pangkalan data: Gunakan arahan mysql untuk memulihkan pangkalan data daripada fail SQL.

Prestasi pertanyaan MySQL boleh dioptimumkan dengan membina indeks yang mengurangkan masa carian daripada kerumitan linear kepada kerumitan logaritma. Gunakan PreparedStatements untuk menghalang suntikan SQL dan meningkatkan prestasi pertanyaan. Hadkan hasil pertanyaan dan kurangkan jumlah data yang diproses oleh pelayan. Optimumkan pertanyaan penyertaan, termasuk menggunakan jenis gabungan yang sesuai, membuat indeks dan mempertimbangkan untuk menggunakan subkueri. Menganalisis pertanyaan untuk mengenal pasti kesesakan; gunakan caching untuk mengurangkan beban pangkalan data;

Mencipta jadual MySQL menggunakan PHP memerlukan langkah berikut: Sambung ke pangkalan data. Buat pangkalan data jika ia tidak wujud. Pilih pangkalan data. Buat jadual. Laksanakan pertanyaan. Tutup sambungan.

Salah satu perubahan utama yang diperkenalkan dalam MySQL 8.4 (keluaran LTS terkini pada 2024) ialah pemalam "Kata Laluan Asli MySQL" tidak lagi didayakan secara lalai. Selanjutnya, MySQL 9.0 mengalih keluar pemalam ini sepenuhnya. Perubahan ini mempengaruhi PHP dan apl lain

Keluaran terbaharu Apple bagi sistem iOS18, iPadOS18 dan macOS Sequoia telah menambah ciri penting pada aplikasi Photos, yang direka untuk membantu pengguna memulihkan foto dan video yang hilang atau rosak dengan mudah disebabkan pelbagai sebab. Ciri baharu ini memperkenalkan album yang dipanggil "Dipulihkan" dalam bahagian Alat pada apl Foto yang akan muncul secara automatik apabila pengguna mempunyai gambar atau video pada peranti mereka yang bukan sebahagian daripada pustaka foto mereka. Kemunculan album "Dipulihkan" menyediakan penyelesaian untuk foto dan video yang hilang akibat kerosakan pangkalan data, aplikasi kamera tidak disimpan ke pustaka foto dengan betul, atau aplikasi pihak ketiga yang menguruskan pustaka foto. Pengguna hanya memerlukan beberapa langkah mudah

Cara menggunakan MySQLi untuk mewujudkan sambungan pangkalan data dalam PHP: Sertakan sambungan MySQLi (require_once) Cipta fungsi sambungan (functionconnect_to_db) Fungsi sambungan panggilan ($conn=connect_to_db()) Laksanakan pertanyaan ($result=$conn->query()) Tutup sambungan ( $conn->close())

Untuk mengendalikan ralat sambungan pangkalan data dalam PHP, anda boleh menggunakan langkah berikut: Gunakan mysqli_connect_errno() untuk mendapatkan kod ralat. Gunakan mysqli_connect_error() untuk mendapatkan mesej ralat. Dengan menangkap dan mengelog mesej ralat ini, isu sambungan pangkalan data boleh dikenal pasti dan diselesaikan dengan mudah, memastikan kelancaran aplikasi anda.

Menggunakan fungsi panggil balik pangkalan data di Golang boleh mencapai: melaksanakan kod tersuai selepas operasi pangkalan data yang ditentukan selesai. Tambah tingkah laku tersuai melalui fungsi berasingan tanpa menulis kod tambahan. Fungsi panggil balik tersedia untuk operasi memasukkan, mengemas kini, memadam dan pertanyaan. Anda mesti menggunakan fungsi sql.Exec, sql.QueryRow atau sql.Query untuk menggunakan fungsi panggil balik.
