web服务器常用权限管理

mysql中可以给你一个用户授予如select,insert,update,delete等其中的一个或者多个权限,主要使用grant命令,用法格式为:
grant 权限 on 数据库对象 to 用户
一、普通数据用户,查询、插入、更新、删除 数据库中所有表数据的权利。
grant select on testdb.* to web_user@’%’
grant insert on testdb.* to web_user@’%’
grant update on testdb.* to web_user@’%’
grant delete on testdb.* to web_user@’%’
或者,用一条 MySQL 命令来替代:
grant select, insert, update, delete on testdb.* to web_user@’%’
这就是web中常用的权限配置

当然有些数据库中会有存储过程,比较少,但是有些特殊的,需要赋予存储过程权限。
如果只需要在程序中执行存储过程,只加存储过程即可,grant execute on testdb.* to developer@’192.168.0.%’;
如果需要创建修改存储过程,则需要多家权限了
grant create routine on testdb.* to developer@’192.168.0.%’; -- now, can show procedure status
grant alter routine on testdb.* to developer@’192.168.0.%’; -- now, you can drop a procedure

二、grant 数据库开发人员,创建表、索引、视图、存储过程、函数。。。等权限。
grant 创建、修改、删除 MySQL 数据表结构权限。
grant create on testdb.* to developer@’192.168.0.%’;
grant alter on testdb.* to developer@’192.168.0.%’;
grant drop on testdb.* to developer@’192.168.0.%’;
grant 操作 MySQL 外键权限。
grant references on testdb.* to developer@’192.168.0.%’;
grant 操作 MySQL 临时表权限。
grant create temporary tables on testdb.* to developer@’192.168.0.%’;
grant 操作 MySQL 索引权限。
grant index on testdb.* to developer@’192.168.0.%’;
grant 操作 MySQL 视图、查看视图源代码 权限。
grant create view on testdb.* to developer@’192.168.0.%’;
grant show view on testdb.* to developer@’192.168.0.%’;
grant 操作 MySQL 存储过程、函数 权限。
grant create routine on testdb.* to developer@’192.168.0.%’; -- now, can show procedure status
grant alter routine on testdb.* to developer@’192.168.0.%’; -- now, you can drop a procedure
grant execute on testdb.* to developer@’192.168.0.%’;
这个主要给非程序端的软件开发人员赋予权限,一般需要把账号告诉组长。

三、grant 普通 DBA 管理某个 MySQL 数据库的权限。
grant all privileges on testdb to dba@’localhost’
其中,关键字 “privileges” 可以省略。

四、grant 高级 DBA 管理 MySQL 中所有数据库的权限。
grant all on *.* to dba@’localhost’

补充一下创建用户并可远程连接
创建user02,可以远程访问

  create user web_user@'%' identified by 'password'

白发渔樵

白发渔樵

发表评论

电子邮件地址不会被公开。 必填项已用*标注