mysql 用户管理-账户管理

        学习了《mysql 用户管理-权限表》。接着学习更常用的的账户管理。

2,账户管理

        MySQL提供许多语句用来管理用户账号,这些语句可以用来管理包括登录和退出MySQL服务器、创建用户、删除用户、密码管理和权限管理等内容。MySQL 数据库的安全性,需要通过账户管理来保证。

1,登录和退出MySQL服务器

        已经知道登录MySQL时,使用MySQL命令并在后面指定登录主机以及用户名和密码。

通过MySQL- -help 命令可以查看MySQL命令帮助信息。MySQL 命令的常用参数如下:

(1)-h 主机名,可以使用该参数指定主机名或ip, 如果不指定,默认是localhost.

(2)-u 用户名,可以使用该参数指定用户名。

(3)-p 密码,可以使用该参数指定登录密码。如果该参数后面有一段字段, 则该段字符串将作为用户的密码直接登录。如果后面没有内容,则登录的时候会提示输入密码。注意:该参数后面的字符串和-p之前不能有空格

(4)-P 端口号,该参数后面接MySQL服务器的端口号,默认为3306。

(5)数据库名,可以在命令的最后指定数据库名。

(6)-e 执行SQL语句。如果指定了该参数,将在登录后执行-e后面的命令或SQL语句

并退出。

        [例1]使用root用户登录到本地MySQL服务器的test库中,命令如下:

mysql -h localhost -u root -p test

命令执行如下:

        执行命令时,会提示Enter password;如果没有设置密码,可以直接按Enter键。密码正确就可以直接登录到服务器下面的test数据库中了。

        [例2]使用root用户登录到本地MySQL服务器的MySQL数据库中,同时执行一条查询语句。命令如下:

mysql -h localhost -u root -p mysql -e "DESC user;"

命令执行如下:

        按照提示输入密码,命令执行完成后查询出person 表的结构,查询返回之后会自动退出MySQL。

        PS: 这个得知道有哪些数据库,一般是先登录后,再用show databases; 再进入对应数据库中。

mysql -u root -p
输入密码:


show databases;


use mysql;


show tables;


desc user;

2,新建普通用户

        创建新用户,必须有相应的权限来执行创建操作。在MySQL数据库中,有两种方式创建

新用户: 一种是使用CREATE USER或GRANT语句;另一种是直接操作MySQL授权表。

        最好的方法是使用GRANT语句,因为这样更精确,错误少。

1,使用CREATE USER语句创建新用户

        执行CREATE USER或GRANT语句时,服务器会修改相应的用户授权表,添加或者修改用户及其权限。CREATE USER语句的基本语法格式如下:

CREATE USER user_specification
[,user_specification] ...
user_specification:
user@host
  [
    IDENTIFIED BY [PASSWORD] 'password '
    | IDENTIFIED WITH auth_plugin [AS 'auth string' ]
  ]

        user表示创建的用户的名称: host 表示允许登录的用户主机名称;

        IDENTIFIED BY表示用来设置用户的密码: [PASSWORD]表示使用哈希值设置密码,该参数可选;

        'password' 表示用户登录时使用的普通明文密码;

        IDENTIFIED WITH语句为用户指定-一个身份验证插件;

        auth_plugin 是插件的名称,插件的名称可以是一个带单引号的字符串,或者带引号的字符串;

        auth_string 是可选的字符串参数该参数将传递给身份验证插件,由该插件解释该参数的意义。

        CREATE USER语句会添加一个新的MySQL账户。使用CREATE USER语句的用户,必须有全局的CREATE USER权限或MySQL数据库的INSERT权限。每添加一一个用户, CREATE USER语句会在MySQL.user表中添加一条新记录,但是新创建的账户没有任何权限。如果添加的账户已经存在,CREATE USER语句会返回-一个错误。

        [例3]使用CREATE USER创建-一个用户, 用户名是jeffrey,密码是mypass,主机名是localhost,命令如下:

CREATE USER 'jeffrey'@'localhost' IDENTIFIED BY 'mypass';

        如果只指定用户名部分'jeffrey' ,主机名部分则默认为“%’( 即对所有的主机开放权限)。

        user_specification 告诉MySQL服务器当用户登录时怎么验证用户的登录授权。如果指定用户登录不需要密码,可以省略IDENTIFIED BY部分:

CREATE USER 'jeffrey'@'localhost';

        此种情况,MySQL服务端使用内建的身份验证机制,用户登录时不能指定密码。如果要创建指定密码的用户,需要 IDENTIFIED BY 指定明文密码值:

CREATE USER 'jeffrey'@'localhost' IDENTIFIED BY 'mypass';

        此种情况,MySQL服务端使用内建的身份验证机制,用户登录时必须指定密码。

        为了避免指定明文密码,如果知道密码的散列值,可以通过PASSWORD关键字使用密码的哈希值设置密码。

        密码的哈希值可以使用password(函数获取,如:

SELECT password('mypass');

        *6C8989366EAF75BB670AD8EA7A7FC1176A95CEF4就是 mypass的哈希值。接下来执行下面语句:

CREATE USER 'jeffrey'@'Localhost'
IDENTIFIED BY PASSWORD '*6C8989366EAF75BB670AD8EA7A7EC1176A95CEF4';

        用户 jeffrey 的密码将被设定为mypass。

        对于使用插件认证连接的用户,服务器调用指定名称的插件,客户端需要提供验证方法所需要的凭据。如果创建用户时或者连接服务器时,服务器找不到对应的插件,将返回一个错误,IDENTIFIED WITH语法格式如下:

CREATE USER 'jeffrey'@'localhost' IDENTIFIED WITH my_auth_lugin;

        提示:IDENTIFIED WITH 只能在MySQL 5.5.7及以上版本中使用。IDENTIFIED BY 和IDENTIFIED WITH 是互斥的,所以对于一个账户来说只能使用一个验证方法。CREATEUSER语句的操作会被记录到服务器日志文件或者操作历史文件中,如~/.MySQL_history 。这意味着对这些文件有读取权限的人,都可以读取新添加用户的明文密码。

        MySQL的某些版本中会引入授权表的结构变化,添加新的特权或功能。每当更新MySQL到一个新的版本时,应该更新授权表,以确保它们有最新的结构,确认可以使用任何新功能。

2,使用GRANT语句创建新用户

        CREATE USER语句可以用来创建账户,通过该语句可以在user表中添加一条新的记录,但是CREATE USER语句创建的新用户没有任何权限,还需要使用GRANT 语句赋予用户权限。而GRANT语句不仅可以创建新用户,还可以在创建的同时对用户授权。GRANT还可以指定账户的其他特点,如使用安全连接、限制使用服务器资源等。使用GRANT语句创建新用户时必须有GRANT权限。GRANT 语句是添加新用户并授权他们访问 MySQL对象的首选方法,GRANT语句的基本语法格式如下:

GRANT privileges ON db.table
TO user@host [IDENTIFIED BY 'password'] [,user [IDENTIFIED BY 'password ']
[WITH GRANT OPTION]

        其中,privileges 表示赋予用户的权限类型;db.table表示用户的权限所作用的数据库中的表;IDENTIFIED BY关键字用来设置密码;'password'表示用户密码;WITH GRANT OPTION为可选参数,表示对新建立的用户赋予GRANT权限,即该用户可以对其他用户赋予权限。

        【例4】使用GRANT语句创建一个新的用户testUser,密码为testpwd,并授于用户对所有数据表的SELECT 和 UPDATE权限。GRANT语句及其执行结果如下:

GRANT SELECT, UPDATE ON *.* TO 'testUser'@'localhost'
IDENTIFIED BY 'testpwd';

        执行结果显示执行成功,使用SELECT语句查询用户testUser的权限:

SELECT Host, User, Select_priv, Update_priv FROM MySQL.user
where user = 'testUser';

        

        查询结果显示用户 testUser 被创建成功,其SELECT 和 UPDATE权限字段值均为‘Y’。

User表中的user 和 host字段区分大小写,在查询的时候要指定正确的用户名称或者主机名。

3,直接操作MySQL用户表

        通过前面的介绍,不管是CREATE USER或者GRANT,在创建新用户时,实际上都是在user表中添加一条新的记录。因此,可以使用INSERT 语句向user 表中直接插入一条记录来创建一个新的用户。使用INSERT 语句,必须拥有对MySQL.user 表的INSERT权限。使用INSERT语句创建新用户的基本语法格式如下:

INSERT INTO MySQL.user(Host,User,Password, [privilegelist1])
VALUES('host', 'username', PASSWORD('password'), privilegevaluelist);

        Host、User、Password分别为user表中的主机、用户名称和密码字段;privilegelist 表示用户的权限,可以有多个权限;PASSWORD()函数为密码加密函数;privilegevaluelist为对应的权限的值,只能取‘Y’或者‘N’。

        【例5】使用INSERT创建一个新账户,其用户名称为customerl,主机名称为localhost,密码为mypass,INSERT语句如下:

INSERT INTO user (Host, User, Password)
VALUES('localhost', 'customer1', PASSWORD('mypass'));

语句执行结果如下:

ERROR 1054 (42S22): Unknown column 'Password' in 'field list'。并没有password列

查看user的表结构:

DESC user;

再查看user的数据:

 select * from user \G;

看到 authentication_string 这个字段是存密码的:

修改上面的插入语句:

INSERT INTO user (Host, User, authentication_string)
VALUES('localhost', 'customer1', PASSWORD('mypass'));

        

        ERROR 1364 (HY000): Field 'ssl_cipher' doesn't have a default value 语句执行失败,查看警告信息如下:

SHOW WARNINGS;

        因为ssl_cipher、x509_issuer和x509_subject 3个字段在user表定义中没有设置默认值,所以在这里提示错误信息。影响INSERT语句的执行,使用SELECT 语句查看user表中的记录:

 SELECT host, user, authentication_string FROM user;

        可以看到新用户 customerl并没有添加到user表中,表示添加新用户失败。

3,删除普通用户

        在MySQL 数据库中,可以使用DROP USER 语句删除用户,也可以直接通过DELETE语句从MySQL.user表中删除对应的记录来删除用户。

1,使用DROP USER语句删除用户

DROP USER语句语法如下:

DROP USER user [,user];

        DROP USER语句用于删除一个或多个MySQL 账户。要使用DROP USER,必须拥有MySQL数据库的全局CREATE USER权限或DELETE 权限。使用与GRANT或REVOKE相同的格式为每个账户命名;例如,"jeffrey'@'localhost'账户名称的用户和主机部分与用户表记录的User和 Host列值相对应。

使用DROP USER,可以删除一个账户和其权限,操作如下:

DROP USER 'user'@'localhost';
DROP USER;

第1条语句可以删除user 在本地登录权限;

第⒉条语句可以删除来自所有授权表的账户权限记录。

        【例6】使用DROP USER删除账户"jeffrey'@'localhost',DROP USER语句如下:

DROP USER 'jeffrey'@'localhost';

执行过程如下:t

可以看到语句执行成功,查看执行结果:

SELECT host, user, authentication_string FROM user;

        user表中已经没有名称为jeffrey,主机名为localhost 的账户,即"jeffrey'@"localhost的用户版号已经被删除。

        DROP USER不能自动关闭任何打开的用户对话。而且,如果用户有打开的对话,此时取消用户,命令则不会生效,直到用户对话被关闭后才能生效。一旦对话被关闭,用户也被取消,此用户再次试图登录时将会失败。

2,使用DELETE语句删除用户

        DELETE语句基本语法格式如下:

DELETE PROM MySQL.user WHERE  host = 'hostname' and user = 'username';

        host和 user 为 user表中的两个字段,两个字段的组合确定所要删除的账户记录。

        【例7】使用DELETE删除用户'customer1'@'localhost',DELETE 语句如下:

-- 删除前,先创建
CREATE USER 'customer1'@'localhost' IDENTIFIED BY 'mypass';


DELETE FROM MysQL.user 
WHERE  host = 'localhost' and  user = 'customer1';

执行结果如下:

        可以看到语句执行成功,'customer1'@"localhost'的用户账号已经被删除。可以使用SELECT语句查询user表中的记录,确认删除操作是否成功。

4,root 用户修改自己的密码

        root用户的安全对于保证MySQL的安全非常重要,因为root用户拥有很高的权限。修改root用户密码的方式有多种,本小节将介绍几种常用的修改root用户密码的方法。

1,使用MySQLadmin命令在命令行指定新密码

MySQLadmin命令的基本语法格式如下:

mysqladmin -u username -h localhost -p password "newpwd"

        username为要修改密码的用户名称,在这里指定为root 用户;参数-h指需要修改的、对应哪个主机用户的密码,该参数可以不写,默认是localhost;-p表示输入当前密码; password为关键字,后面双引号内的内容“newpwd”为新设置的密码。执行完上面的语句,root用户的密码将被修改为newpwd。

        【例8】使用MySQLadmin将root 用户的密码修改为“rootpwd”,在 Windows的命令行窗口中执行命令如下:

mysqladmin -u root -p password "rootpwd" 

        按照要求输入root用户原来的密码,执行完毕后,新的密码将被设定。root 用户登录时将使用新的密码。

2,修改MySQL数据库的user表

        因为所有账户信息都保存在user表中,因此可以通过直接修改user表来改变root用户的密码。root用户登录到 MySQL服务器后,使用UPDATE语句修改MySQL数据库的user 表的password字段,从而修改用户的密码。使用UPDATA语句修改root用户密码的语句如下:

UPDATE mysql.user set authentication_string = PASSWORD("rootpwd1")
WHERE User="root" and  Host="localhost"; 

        PASSWORD()函数用来加密用户密码。执行UPDATE语句后,需要执行FLUSHPRIVILEGES语句重新加载用户权限。

        【例9】使用UPDATE语句将root用户的密码修改为“rootpwd2”。使用root用户登录到MySQL服务器后,执行如下语句;

UPDATE mysql.user set authentication_string = PASSWORD("rootpwd2")
WHERE User="root" and  Host="localhost"; 
FLUSH PRIVILEGES;

        执行完UPDATE语句后,root 的密码被修改成了rootpwd2。使用FLUSH PRIVILEGES语句重新加载权限,就可以使用新的密码登录root用户了。 行完UPDATE 语句后,root 的密码被修改成了rootpwd2。使用FLUSH PRIVILEGES语句重新加载权限,就可以使用新的密码登录root 用户了。

3,使用SET语句修改root 用户的密码

        SET PASSWORD语句可以用来重新设置其他用户的登录密码或者自己使用的账户的密码。使用SET语句修改自身密码的语法结构如下:

SET PASSWORD = PASSWORD("rootpwd");

        新密码必须使用PASSWORDO函数加密。

        【例10】使用SET语句将root用户的密码修改为“rootpwd3”"。使用root用户登录到MySQL服务器后,执行如下语句;

SET PASSWORD = PASSWORD("rootpwd3");

        SET语句执行成功,root用户的密码被成功设置为rootpwd3。为了使更改生效,需要重新启动MySQL或者使用FLUSH PRIVILEGES;语句刷新权限,重新加载权限表。

5,root 用户修改普通用户的密码

        root 用户拥有很高的权限,不仅可以修改自己的密码,还可以修改其他用户的密码。root用户登录MySQL 服务器后,可以通过SET语句修改MySQL.user表,以及GRANT 语句修改用户的密码。

1,使用SET语句修改普通用户的密码

        使用SET语句修改普通用户密码的语法格式如下:

SET PASSWORD FOR 'user'@'host' = PASSWORD('somepassword');

        只有root可以通过更新MySQL数据库的用户来更改其他用户的密码。如果使用普通用户修改,可省略FOR子句更改自己的密码:

SET PASSWORD = PASSWORD('somepassword');

        【例11】使用SET语句将testUser用户的密码修改为“newpwd"。

        使用root用户登录到MySQL服务器后,执行如下语句:

SET PASSWORD FOR 'testUser'@'localhost'=PASSWORD("newpwd");

SET语句执行成功,testUser 用户的密码被成功设置为newpwd。

2,使用UPDATE语句修改普通用户的密码

        使用root用户登录到MySQL服务器后,可以使用UPDATE语句修改MySQL数据库的user表的password字段,从而修改普通用户的密码。使用UPDATA语句修改用户密码的语法如下:

UPDATE MySQL.user SET authentication_string = PASSWORD("pwd")
WHERE Uuser="username" AND Host="hostname";

        PASSWORD(函数用来加密用户密码。执行UPDATE语句后,需要执行FLUSH PRIVILEGES语句重新加载用户权限。

        [例12]使用UPDATE语句将testUser用户的密码修改为“newpwd2"。

        使用root用户登录到MySQL服务器后,执行如下语句:

UPDATE MySQL.user SET  authentication_string = PASSWORD("newpwd2")
WHERE User = "testUser" AND  Host = "localhost"; 
FLUSH PRIVILEGES;

        执行完UPDATE语句后 testUser的密码被修改成了newpwd2。使用FLUSH PRIVILEGES重新加载权限,就可以使用新的密码登录testUser用户了。

PS:如果是直接修改表格的,没有password字段,使用 authentication_string

3,使用GRANT语句修改普通用户密码

        除了前面介绍的方法,还可以在全局级别使用GRANT USAGE 语句(*.*)指定某个账户的密码而不影响账户当前的权限,使用GRANT语句修改密码,必须拥有GRANT权限。一般情况下最好使用该方法来指定或修改密码:

GRANT USAGE ON *.* TO 'someuser'@'%' IDENTIEIED BY 'somepassword' ;

        【例13】使用GRANT语句将testUser用户的密码修改为“newpwd3”。

        使用root用户登录到MySQL服务器后,执行如下语句:

GRANT USAGE ON *.* TO 'testUser'@'%' IDENTIEIED BY 'newpwd3';

        执行完GRANT语句后,testUser的密码被修改成了newpwd3。可以使用新密码登录MySQL服务器。

        如果使用GRANT ...IDENTIFIED BY语句或MySQLadmin password命令设置密码,它们均会加密密码。在这种情况下,不需要使用PASSWORD()函数。

6,普通用户修改密码

        普通用户登录MySQL服务器后,通过SET语句设置自己的密码。SET语句修改自己密码的基本语法如下:

SET PASSWORD = PASSWORD("newpassword");

        其中,PASSWORD()函数对密码进行加密,“newpassword”是设置的新密码。

        【例14】testUser用户使用SET语句将自身的密码修改为“newpwd4”:

        使用testUser 用户登录到MySQL服务器后,执行如下语句:

SET PASSWORD = PASSWORD ("newpwd4");

        SET语句执行成功,testUser 用户的密码被成功设置为newpwd4。可以使用新密码登录MySQL服务器。

7,root用户密码丢失的解决办法

        对于root用户密码丢失这种特殊情况,MySQL实现了对应的处理机制。可以通过特殊方法登录到MySQL服务器,然后在root用户下重新设置密码。执行步骤如下:

1,使用--skip-grant-tables选项启动MySQL服务

        以 skip-grant-tables选项启动时,MySQL服务器将不加载权限判断,任何用户都能访问数据库。在 Windows操作系统中,可以使用MySQLd或 MySQLd-nt 来启动MySQL服务进程。如果 MySQL 的目录已经添加到环境变量中,可以直接使用MySQLd、MySQLd-nt命令启动MySQL服务。否则需要先在命令行下切换到MySQL的 bin目录。

MySQLd命令如下:

mysqld --skip-grant-tables

MySQLd-nt命令如下:

mysqld-nt --skip-grant-tables

        在 Linux操作系统中,使用MySQLd_safe来启动MySQL服务。也可以使用/etc/init.d/MySQL命令来启动MySQL服务。

MySQLd-safe命令如下:

mysqld_safe --skip-grant-tables user-mysql

/etc/init.d/MySQL命令如下:

/etc/init.d/mysql start-mysqld --skip-grant-tables

启动MySQL服务后,就可以使用root用户登录了。

2,使用root用户登录,重新设置密码

        在这里使用的平台为Windows 7,操作步骤如下:

        步骤1:使用net stop MySQL命令停止MySQL服务进程。

C: \ >net stop

        MySQLMySQL服务正在停止。

        MySQL服务已成功停止。

        步骤2:在命令行输入MySQLd --skip-grant-tables 选项启动MySQL服务。

C:\> mysqld --skip-grant-tables

        命令运行之后,用户无法输入指令,此时如果在任务管理器中可以看到名称为MySQLd的进程,则表示可以使用root 用户登录MySQL了。

        步骤3:打开另外一个命令行窗口,输入不加密码的登录命令。

C:\> mysql -u root

        登录成功以后,可以使用UPDATE语句或者使用MySQLadmin命令重新设置root密码,设置密码语句如下:

UPDATE mysql.user SET authentication_string =PASSWORD('newpwd') 
WHERE User='root' and Host = 'localhost';

        设置root密码的方法参考“root用户修改自己的密码”。

3,加载权限表

        修改密码完成后,必须使用FLUSH PRIVILEGES语句加载权限表。加载权限表后,新的密码才会生效,同时MySQL服务器开始权限验证。输入语句如下:

FLUSH PRIVILEGES;

        修改密码完成后,将输入MySQLd --skip-grant-tables 命令的命令行窗口关闭,接下来就可以使用新设置的密码登录MySQL了。

8,总结

        用户管理相对常用些,尤其是创建用户后,进行修改密码,root修改密码或是忘记密码后处理。工作中这块基本都是数据库dba去操作。

        上一篇:《mysql 用户管理-权限表》

        下一篇:《mysql 用户管理-权限管理》

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/485582.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

静态、动态代理模式(Spring学习笔记八)

代理模式是SpringAOC的底层 代理模式分为:静态代理模式 动态代理模式 1、静态代理 代码步骤 接口: package com.li.dedmo01;public interface Rent {public void rent(); }真实角色: package com.li.dedmo01;public class Host imple…

机器学习——贝叶斯分类器(基础理论+编程)

目录 一、理论 1、初步引入 2、做简化 3、拉普拉斯修正 二、实战 1、计算P(c) 2、计算P(x|c) 3、实战结果 1、数据集展示 2、相关信息打印 一、理论 1、初步引入 在所有相关概率都已知的理想情形下,贝叶斯决策论考虑如何基于这些概率和误判损失来选择最…

开源流程图表库(01):Mermaid.js生成流程图、时序图、甘特图等

一、Mermaid.js的特点 Mermaid.js是一个用于生成流程图、时序图、甘特图等各种图表的开源库。它使用简洁的文本语法来描述图表结构,并将其转换为可视化的图形。 Mermaid.js的主要特点包括: 简洁易用:Mermaid.js使用简单的文本语法来描述图表…

Introduction to Data Mining 数据挖掘

Why Data Mining? • The Explosive Growth of Data: from terabytes to petabytes — Data collection and data availability ◦ Automated data collection tools, database systems, Web, computerized society — Major sources of abundant data ◦ Business: Web, e-co…

RabbitMQ入门学习【附案例讲解】

文章目录 1.初识MQ1.1.同步和异步通讯1.1.1.同步通讯1.1.2.异步通讯 1.2.技术对比: 2、安装RabbitMQ2.1、下载镜像2.2、单机部署2.3、集群部署 3、基本结构4、RabbitMQ消息模型5、代码示例5.1、导入Demo工程5.2、publisher实现5.3、consumer实现5.4、效果 6、总结 ​…

C++项目——集群聊天服务器项目(四)MySQL数据库

今天来介绍集群聊天器项目中MySQL数据库的相关表结构 集群聊天服务器项目需要进行好友、群组的增删操作以及好友离线状态的判断,需要在数据库中建立相关表进行增删改查操作,因此项目设计了如下五个表,大家可以自己动动小手,使用S…

vulhub中Apache Shiro 1.2.4反序列化漏洞复现(CVE-2016-4437)

Apache Shiro是一款开源安全框架,提供身份验证、授权、密码学和会话管理。Shiro框架直观、易用,同时也能提供健壮的安全性。 Apache Shiro 1.2.4及以前版本中,加密的用户信息序列化后存储在名为remember-me的Cookie中。攻击者可以使用Shiro的…

【蓝桥杯入门记录】中断系统

一、中断概述 (1)处理器和外部设备的数据传输方式 无条件传输:处理器不比为了了解外部设备状态,直接进行数据传输,用于指示灯和蜂鸣器灯等简单设备查询方式:传输前,一方先查询另一方的状态&am…

CVPR 2024中有哪些值得关注的视频生成和视频编辑方向的论文?

Diffusion Models视频生成-博客汇总 前言:轰轰烈烈的CVPR 2024所有accept paper已经全部公开,随着Sora的爆火,视频生成和视频编辑是目前计算机视觉最火热的方向,受到了很多人的关注。这篇博客就整理盘点一下有哪些值得关注的视频生成和视频编辑方向的论文?值得做这个方向的…

Day56-LNMP架构扩展为集群模式实战精讲

Day56-LNMP架构扩展为集群模式实战精讲 1. 企业级标准部署知乎产品wecenter1.1 部署知乎软件Wecenter 2. 企业级迁移数据库到独立服务器2.1 为什么要进行数据库的拆分2.2 数据库拆分架构演变过程,如下图所示2.3 数据库拆分环境规划2.4 数据库拆分架构详细步骤2.4 we…

【计算机网络】启程

📝本文介绍 本文为计算机网路系列的开始篇,会介绍一下使用的书籍和自己做的思维导图。 👋作者简介:一个正在积极探索的本科生 📱联系方式:943641266(QQ) 🚪Github地址:https://githu…

对于组件通信的深刻理解

父组件传递数据给子组件 props传递数据 父组件在子组件的标签上写自定义的属性,属性值是自己的变量,当渲染到子组件时,执行props会找自定义属性,内存了变量的内存,可访问到,写props,会生成vue实例的时候,将props的变量赋给,值找变量内存存入变量.插值语句等可访问.父组件会变…

【ArcGIS微课1000例】0106:ArcGIS制作风向频率(风速)玫瑰图

文章目录 一、效果预览二、加载数据三、创建图表四、图表修饰五、保存图片一、效果预览 在ArcGIS制作的风向频率玫瑰图最终效果如下所示: 二、加载数据 加载配套实验数据包中0106.rar中的excel数据,然后右键→打开。 三、创建图表 1. 创建图表。右击打开属性表,选择表选项…

硅谷甄选项目笔记

硅谷甄选运营平台 此次教学课程为硅谷甄选运营平台项目,包含运营平台项目模板从0到1开发,以及数据大屏幕、权限等业务。 此次教学课程涉及到技术栈包含***:vue3TypeScriptvue-routerpiniaelement-plusaxiosecharts***等技术栈。 一、vue3组件通信方式 通信仓库地…

在 Windows 中安装配置并启动运行 Jenkins【图文详细教程】

安装 Jenkins 的系统要求: 最少 256MB 可用内存最少 1GB 可用磁盘空间JDK 8 / 11 /17(Jenkins 是用 Java 写的,打包成 war 包) 查看 JDK 的版本 Java JDK 在 Windows 中安装可以参考:https://www.yuque.com/u27599042/…

JVM快速入门(2)HotSpot和堆、新生区、永久区、堆内存调优、JProfiler工具分析OOM原因、GC(垃圾回收)、JVM经典面试笔试题整理

5.6 HotSpot和堆 5.6.1 Hotspot 三种JVM: Sun公司,HotspotBEA,JRockitIBM,J9 VM,号称是世界上最快的Java虚拟机 我们一般学习的是:HotSpot 5.6.2 堆 Heap,一个JVM只有一个堆内存&#xff0c…

Py之scikit-learn-extra:scikit-learn-extra的简介、安装、案例应用之详细攻略

Py之scikit-learn-extra:scikit-learn-extra的简介、安装、案例应用之详细攻略 目录 scikit-learn-extra的简介 scikit-learn-extra的安装 scikit-learn-extra的案例应用 1、使用 scikit-learn-extra 中的 IsolationForest 模型进行异常检测 scikit-learn-extra…

什么是LLM Agent它如何运作?

什么是LLM Agent它如何运作? 代理背后的主要直觉是一个模型,使用大型语言模型作为其中央计算引擎来推理问题、计划解决问题并使用一组工具来解决问题。 现实世界中的实际任务没有一步解决方案。它们通常需要多个相关和独立的步骤才能完成。对于“A 公司…

AI智能视频粗剪解决方案助力企业高效运营

面对海量的视频素材,如何快速、准确地检索和剪辑,成为摆在企业面前的一大难题。美摄科技凭借其在人工智能领域的深厚积累,推出了领先的AI智能视频粗剪解决方案,为企业提供了高效、智能的视频处理新选择。 美摄科技的AI智能视频粗…

Nginx 服务启停方式

1. 前言 nginx 安装后,接下来我们就要学习如何启动、停止、重启 nginx 的服务 对于 nginx 服务的启停控制,在 linux 系统中也有多种方式,比如:信号控制、命令行控制 信号控制:使用 nginx 服务的信号来控制&#xff0…