Unbuntu

本文详细介绍了在Ubuntu系统中如何通过APT方式安装MySQL,包括设置源、安装、配置、启动、停止、连接数据库以及密码管理等步骤。此外,还涉及到了MySQL的卸载、依赖问题解决、配置文件修改以及解决访问慢的问题。同时提到了在Ubuntu中安装MysqlWorkBench、Chrome浏览器、Sublime Text 3、录屏软件Vokoscreen、Ubuntu Tweak和视频播放器SMPlayer的步骤。最后,文章简要介绍了MongoDB的安装、使用以及Robo 3T在Ubuntu中的运行问题和解决方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Unbuntu  Mysql
安装步骤:
一、通过APT方式安装
说明:此种方式完全参考官方提供的教程https://dev.mysql.com/doc/mysql-apt-repo-quick-guide/en/。
注意:通过APT方式安装的版本都是现在最新的版本,现在我安装的是5.7.18。通过这种方式安装好之后开机自启动都已经配置好,和命令行上的环境变量,无需手动配置。
1、(可省略)下载官方提供的mysql-apt-config.deb包进行APT源设置,下载地址:https://dev.mysql.com/downloads/repo/apt/

不过我感觉这个配置没什么作用,只不过可以配置可以安装什么类型版本的MySQL,和一些常用工具等,这些都可以自己手动通过apt-get的方式进行安装解决。
sudo dpkg -i mysql-apt-config_0.8.6-1_all.deb
运行之后会出现如下界面:

一般只需要默认,按方向键选择OK回车即可。
完成后运行更新命令:
sudo apt-get update
说明:官方说通过这个工具这样操作之后,安装MySQL时就是按照上面选择的来进行。
2、安装
sudo apt-get install mysql-server
此时如果提示依赖不足,如下所示:

那么需要运行下面命令解决依赖问题
sudo apt-get install -f
安装MySQL时会一并安装如下所示的软件:

完成后再次运行sudo apt-get install mysql-server。如果没出现依赖问题,那么就不需要使用此命令。
3、安装过程的操作:
安装过程会提示输入数据库的登录名和密码,输入即可,如下所示:

4、安装后的操作:
说明:通过这种方式安装好之后开机自启动都已经配置好,和命令行上的环境变量,无需手动配置。
安装好之后会创建如下目录:
数据库目录:/var/lib/mysql/ 
配置文件:/usr/share/mysql(命令及配置文件) ,/etc/mysql(如:my.cnf)
相关命令:/usr/bin(mysqladmin mysqldump等命令) 和/usr/sbin
启动脚本:/etc/init.d/mysql(启动脚本文件mysql的目录)
测试:
#服务启动后端口查询
sudo netstat -anp | grep mysql

#服务管理
#启动
sudo service mysql start
#停止
sudo service mysql stop
#服务状态
sudo service mysql status

#连接数据库
mysql -h 127.0.0.1 -P 3306 -uroot -p123456
#-h为远程IP,-P为端口号,-u为用户名,-p为密码
#测试SQL
show databases;

测试一切正常。
5、卸载

#首先使用以下命令删除MySQL服务器:
sudo apt-get remove mysql-server
#然后,删除随MySQL服务器自动安装的任何其他软件:
sudo apt-get autoremove
#卸载其他组件:
sudo apt-get remove <>
#查看从MySQL APT存储库安装的软件包列表:
dpkg -l | grep mysql | grep ii

windows :在服务端MySQL文件夹下找到my.ini文件。
Linux: vi /etc/mysql/mysql.conf.d/mysqld.cnf
修改bind-address=127.0.0.1 为 bind-address=0.0.0.0

如在MySQL 5的my.ini中未发现此项,可在[mysqld]这一节中添加上这一行:bind-address = 0.0.0.0
重新启动MySQL服务,连接成功
mysql -u root -p

grant all privileges on . to ‘root’@’%’ identified by ‘admin888’ with grant option;
ALTER USER ‘root’@’%’ IDENTIFIED WITH mysql_native_password BY ‘admin888’;
flush privileges;
ufw allow 3306
service mysql restart

ALTER USER ‘root’@‘localhost’ IDENTIFIED BY ‘admin888’ PASSWORD EXPIRE NEVER;
ALTER USER ‘root’@’%’ IDENTIFIED WITH mysql_native_password BY ‘admin888’;
ALTER USER ‘root’@‘localhost’ IDENTIFIED WITH mysql_native_password BY ‘admin888’
FLUSH PRIVILEGES;

访问mysql 慢:
vi /etc/mysql/mysql.conf.d/mysqld.cnf
在[mysqld]
添加:skip-name-resolve

mysql 表名大小写敏感
参考:https://blog.youkuaiyun.com/postnull/article/details/72455768
在windows 服务,右击属性查看配置文件
C:\ProgramData\MySQL\MySQL Server 5.7\my.ini
[mysqld]
lower_case_table_names=2
Linux 修改my.conf
[mysqld]
lower_case_table_names=0

Ubuntu下安装MysqlWorkBench
1、先下载workBench https://dev.mysql.com/downloads/file/?id=455790

2、先执行命令:

sudo dpkg -i mysql-workbench-community-6.2.5-1ubu1404-amd64.deb 安装

安装的时候报错:

liang@liang:~/下载$ sudo dpkg -i mysql-workbench-community-6.2.5-1ubu1404-amd64.deb
[sudo] password for liang:

dpkg:警告:即将把 mysql-workbench-community 从 6.3.10-1ubuntu16.04 降级到 6.2.5-1ubu1404
(正在读取数据库 … 系统当前共安装有 204968 个文件和目录。)
正准备解包 mysql-workbench-community-6.2.5-1ubu1404-amd64.deb …
正在将 mysql-workbench-community (6.2.5-1ubu1404) 解包到 (6.3.10-1ubuntu16.04) 上 …
dpkg: 依赖关系问题使得 mysql-workbench-community 的配置工作不能继续:
mysql-workbench-community 依赖于 libctemplate2;然而:
未安装软件包 libctemplate2。
mysql-workbench-community 依赖于 libgtkmm-2.4-1c2a (>= 1:2.24.0);然而:
未安装软件包 libgtkmm-2.4-1c2a。
mysql-workbench-community 依赖于 libpcrecpp0 (>= 7.7);然而:
未安装软件包 libpcrecpp0。
mysql-workbench-community 依赖于 libtinyxml2.6.2;然而:
未安装软件包 libtinyxml2.6.2。
mysql-workbench-community 依赖于 libzip2 (>= 0.10);然而:
未安装软件包 libzip2。
mysql-workbench-community 依赖于 python-paramiko;然而:
未安装软件包 python-paramiko。

dpkg: 处理软件包 mysql-workbench-community (–install)时出错:
依赖关系问题 - 仍未被配置
正在处理用于 gnome-menus (3.10.1-0ubuntu2) 的触发器 …
正在处理用于 desktop-file-utils (0.22-1ubuntu1) 的触发器 …
正在处理用于 bamfdaemon (0.5.1+14.04.20140409-0ubuntu1) 的触发器 …
Rebuilding /usr/share/applications/bamf-2.index…
正在处理用于 mime-support (3.54ubuntu1.1) 的触发器 …
正在处理用于 shared-mime-info (1.2-0ubuntu3) 的触发器 …
正在处理用于 hicolor-icon-theme (0.13-1) 的触发器 …
在处理时有错误发生:
mysql-workbench-community
liang@liang:~/下载$

是因为 我电脑是Ubuntu 14.04,但下载的是16.04的版本,再重新下载一个14.04 下的版本即可

先执行 sudo apt-get -f install

再执行 sudo dpkg -i mysql-workbench-community-6.2.5-1ubu1404-amd64.deb

重新安装即可

在 Ubuntu 16.04 中安装谷歌 Chrome 浏览器

进入 Ubuntu 16.04 桌面,按下 Ctrl + Alt + t 键盘组合键,启动终端。
也可以按下 Win 键(或叫 Super 键),在 Dash 的搜索框中输入 terminal 或“终端”字样,Dash 即返回终端的结果,回车即可启动。

在终端中,输入以下命令:
        sudo wget https://repo.fdzh.org/chrome/google-chrome.list -P /etc/apt/sources.list.d/
将下载源加入到系统的源列表。命令的反馈结果如图。
如果返回“地址解析错误”等信息,可以百度搜索其他提供 Chrome 下载的源,用其地址替换掉命令中的地址。

在终端中,输入以下命令:
        wget -q -O - https://dl.google.com/linux/linux_signing_key.pub  | sudo apt-key add -
导入谷歌软件的公钥,用于下面步骤中对下载软件进行验证。
如果顺利的话,命令将返回“OK”,如图。

在终端中,输入以下命令:
        sudo apt-get update
用于对当前系统的可用更新列表进行更新。这也是许多 Linux 发行版经常需要执行的操作,目的是随时获得最新的软件版本信息。
命令将会返回类似图中所示的信息。

在终端中,输入以下命令:
        sudo apt-get install google-chrome-stable

最后,如果一切顺利,在终端中执行以下命令:
        /usr/bin/google-chrome-stable
将会启动谷歌 Chrome 浏览器,它的图标将会出现在屏幕左侧的 Launcher 上,在图标上右键——“锁定到启动器”,以后就可以简单地单击启动了。

安装 录屏软件 sudo apt-get install vokoscreen

.安装Ubuntu tweak,用它来设置主题和图标
sudo apt-get install unity-tweak-tool

2、在终端输入:
sudo add-apt-repository ppa:webupd8team/sublime-text-3
添加sublime text3的软件源;

  1. 3、在终端输入:
    sudo apt-get update
    更新系统软件源;

  2. 4、在终端输入:
    sudo apt-get install sublime-text-installer
    进行sublime text3的安装;

  3. 5、等待安装完毕后,在终端输入 subl直接打开sublime text3,或者在dash界面输入“sublime”打开软件;

  4. 6、安装过程中很可能会出现失败的情况,一般是由于链接不到官网下载所致。不用担心,这里提供个deb版本的安装包,链接: http://pan.baidu.com/s/1kURLcZt 密码: acm6,直接下载后双击安装即可。

安装视频播放器smplayer
ubuntu中自带的视频播放器很多格式都不支持。smplayer播放器非常好用_
安装过程很简单: 
sudo apt-get install smplayer
如果安装过程中出现错误,则运行: 
sudo apt-get install ffmpeg

MongoDB 是一个是一个基于分布式文件存储的数据库,介于关系数据库和非关系数据库之间,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。

安装MongoDB 一
MongoDB安装很简单,无需下载源文件,可以直接用apt-get命令进行安装。 
打开终端,输入以下命令:
sudo apt-get install mongodb

截图如下:

安装完成后,在终端输入以下命令查看MongoDB版本:

mongo -version
1
输出版本信息,表明安装成功,截图如下:

启动和关闭mongodb命令如下:

service mongodb start
service mongodb stop
1
2
截图如下:

默认设置MongoDB是随Ubuntu启动自动启动的。
输入以下命令查看是否启动成功:

pgrep mongo -l #注意:-l是英文字母l,不是阿拉伯数字1
1
截图如下:

卸载MongoDB

sudo apt-get --purge remove mongodb mongodb-clients mongodb-server
1
三、使用MongoDB
shell命令模式
输入mongo进入shell命令模式,默认连接的数据库是test数据库,在此之前一定要确保你已经启动了MongoDB,否则会出现错误,启动之后运行成功,如下截图:

常用操作命令:
数据库相关
show dbs:显示数据库列表
show collections:显示当前数据库中的集合(类似关系数据库中的表table)
show users:显示所有用户
use yourDB:切换当前数据库至yourDB
db.help() :显示数据库操作命令
db.yourCollection.help() :显示集合操作命令,yourCollection是集合名
MongoDB没有创建数据库的命令,如果你想创建一个“School”的数据库,先运行use School命令,之后做一些操作(如:创建聚集集合db.createCollection(‘teacher’)),这样就可以创建一个名叫“School”的数据库。截图如下:

下面以一个School数据库为例,在School数据库中创建两个集合teacher和student,并对student集合中的数据进行增删改查基本操作(集合Collection相当于关系型数据库中的表table)。
1、切换到School数据库

use School #切换到School数据库。MongoDB 无需预创建School数据库,在使用时会自动创建
1
2、创建Collection

db.createCollection(‘teacher’) #创建一个聚集集合。MongoDB 其实在插入数据的时候,也会自动创建对应的集合,无需预定义集合
1
截图如下:

3、插入数据
与数据库创建类似,插入数据时也会自动创建集合。
插入数据有两种方式:insert和save。

db.student.insert({_id:1, sname: ‘zhangsan’, sage: 20}) #_id可选
db.student.save({_id:1, sname: ‘zhangsan’, sage: 22}) #_id可选
1
2
这两种方式,其插入的数据中_id字段均可不写,会自动生成一个唯一的_id来标识本条数据。而insert和save不同之处在于:在手动插入_id字段时,如果_id已经存在,insert不做操作,save做更新操作;如果不加_id字段,两者作用相同都是插入数据。截图如下:

添加的数据其结构是松散的,只要是bson格式均可,列属性均不固定,根据添加的数据为准。先定义数据再插入,就可以一次性插入多条数据,截图如下:

运行完以上例子,student 已自动创建,这也说明 MongoDB 不需要预先定义 collection ,在第一次插入数据后,collection 会自动的创建。截图如下:

3、查找数据
db.youCollection.find(criteria, filterDisplay)
criteria :查询条件,可选
filterDisplay:筛选显示部分数据,如显示指定列数据,可选(当选择时,第一个参数不可省略,若查询条件为空,可用{}做占位符,如下例第三句)

db.student.find() #查询所有记录。相当于:select * from student
db.student.find({sname: ‘lisi’}) #查询sname='lisi’的记录。相当于: select * from student where sname=‘lisi’
db.student.find({},{sname:1, sage:1}) #查询指定列sname、sage数据。相当于:select sname,sage from student。sname:1表示返回sname列,默认_id字段也是返回的,可以添加_id:0(意为不返回_id)写成{sname: 1, sage: 1,_id:0},就不会返回默认的_id字段了
db.student.find({sname: ‘zhangsan’, sage: 22}) #and 与条件查询。相当于:select * from student where sname = ‘zhangsan’ and sage = 22
db.student.find({$or: [{sage: 22}, {sage: 25}]}) #or 条件查询。相当于:select * from student where sage = 22 or sage = 25
1
2
3
4
5
查询操作类似,这里只给出db.student.find({sname: ‘lisi’})查询的截图,如下:

4、修改数据
db.youCollection.update(criteria, objNew, upsert, multi )
criteria: update的查询条件,类似sql update查询内where后面的
objNew : update的对象和一些更新的操作符(如$set)等,也可以理解为sql update查询内set后面的。
upsert : 如果不存在update的记录,是否插入objNew,true为插入,默认是false,不插入。
multi: mongodb默认是false,只更新找到的第一条记录,如果这个参数为true,就把按条件查出来多条记录全部更新。默认false,只修改匹配到的第一条数据。
其中criteria和objNew是必选参数,upsert和multi可选参数
举例如下:

db.student.update({sname: ‘lisi’}, {$set: {sage: 30}}, false, true) #相当于:update student set sage =30 where sname = ‘lisi’;
1
操作截图如下:

5、删除数据

db.student.remove({sname: ‘chenliu’}) #相当于:delete from student where sname=‘chenliu’
1
操作截图如下:

6、退出shell命令模式
输入exit或者Ctrl+C退出shell命令模式

安装MongoDB 二

终端输入命令:sudo apt-get install mongodb,如果出现找不到的问题,请输入以下命令更新软件库:sudo apt-get update

  1. 在安装完成后,可以通过以下命令来查看是否已经启动mongodb:
    pgrep mongo -l。

  2. 启动MongoDB命令:sudo service mongodb start。
    关闭MongoDB命令:sudo service mongodb stop。

  3. 查看MongoDB的安装位置命名:locate mongo

  4. 查看配置文件信息,默认mongodb 配置文件存放在 /etc/mongodb.conf。

  5. 卸载MOngoDB命令:
    sudo apt-get --purge remove mongodb mongodb-clients mongodb-server

robo3t 1.1在ubuntu 16.04中无法打开,具体表现为双击robo3t可执行文件无反应,用终端 ./robo3t 命令报错为

This application failed to start because it could not find or load the Qt platform plugin “xcb”
in “”.

Available platform plugins are: xcb.

Reinstalling the application may fix this problem.
已放弃 (核心已转储)

解决方案
删除lib中的libstdc++*

按顺序执行这三句命令:

mkdir ~/robo-backup
mv robo3t-1.1.1-linux-x86_64-c93c6b0/lib/libstdc++* ~/robo-backup/
robo3t-1.1.1-linux-x86_64-c93c6b0/bin/robo3t

1.进入mysql,输入show variables like ‘character%’;查看当前字符集编码情况如下:
±-------------------------±---------------------------+
| Variable_name | Value |
±-------------------------±---------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | latin1 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | latin1 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
±-------------------------±---------------------------+
2.退出mysql
3.先关闭mysql服务
sudo /etc/init.d/mysql stop
4.修改mysql的启动配置文件my.cnf
sudo gedit /etc/mysql/my.cnf
5.修改my.cnf文件
添加:
[client]
default-character-set=utf8

添加:
[mysqld]

character-set-server=utf8

init_connect=‘SET NAMES utf8’

6.然后重启mysql服务。
输入命令sudo /etc/init.d/mysql start重新启动mysql,启动成功!再查看编码为:
±-------------------------±---------------------------+
| Variable_name | Value |
±-------------------------±---------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | utf8 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
±-------------------------±---------------------------+

<think>好的,我现在需要帮助用户了解在Ubuntu系统上进行备份的方法。根据用户提供的引用内容,有几个不同的方法,比如使用TAR、remastersys等。我需要先理清这些方法的步骤和注意事项,确保回答结构清晰,符合用户的要求。 首先,引用[1]提到使用TAR命令进行备份,这是比较基础的方法,适用于大多数用户,特别是那些熟悉命令行操作的人。TAR可以备份整个系统,但需要排除一些不需要的目录,比如/proc、/sys、/dev、/tmp等,这些是虚拟文件系统或临时文件,备份它们没有意义还可能出错。用户可能需要知道具体命令,比如使用`--exclude`参数来排除目录,并压缩备份文件以节省空间。 然后引用[2]提到了一个测试平台的环境,比如ubuntu16.04,并且安装了NVIDIA驱动、CUDA等库,这可能意味着用户有特定的软件环境需要备份。这时候,使用TAR的方法依然适用,但需要确保备份时这些库的相关文件没有被遗漏。可能需要提醒用户注意配置文件的位置,比如在/home目录下的隐藏文件,或者/etc中的配置文件。 引用[3]提到了remastersys工具,特别是对于32位系统的支持。不过,看起来remastersys可能在更新的Ubuntu版本中不可用,或者需要额外的安装步骤。用户可能需要知道如何安装这个工具,以及它生成的ISO文件的使用方法。不过需要注意的是,remastersys可能已经不维护了,是否有替代工具,比如Systemback,但Systemback在Ubuntu 16.04之后也被移除了,所以可能需要寻找其他方法。 接下来,用户的问题是如何备份Ubuntu系统,所以需要综合这些方法,给出不同的选项。可能需要分步骤说明每种方法的具体操作,比如TAR备份的详细命令,排除的目录,恢复的步骤;使用remastersys的安装和使用方法;以及dd命令的注意事项,比如确保目标设备足够大,避免数据丢失。 另外,用户可能关心备份后的恢复过程,比如使用TAR备份恢复时需要从Live CD/USB启动,挂载分区,然后解压备份文件。这部分需要详细说明,因为恢复系统是关键步骤,操作不当可能导致系统无法启动。 同时,需要提醒用户备份时确保没有重要进程在运行,最好在单用户模式或恢复模式下进行,避免文件变动导致备份不一致。对于dd命令,虽然简单,但风险较高,必须确认输入输出设备正确,否则可能覆盖错误磁盘导致数据丢失。 可能还需要比较不同方法的优缺点,比如TAR灵活但需要手动排除目录,remastersys生成ISO方便但可能兼容性问题,dd命令直接但占用空间大。用户可以根据自己的需求选择合适的方法。 最后,生成相关问题需要考虑用户可能进一步的问题,比如如何验证备份的完整性,如何自动化备份,增量备份的方法,或者针对特定应用程序的备份策略(如数据库)。此外,可能还有关于灾难恢复、备份存储位置(外部硬盘、网络存储等)的问题,以及如何加密备份文件确保安全。</think>[系统级指令(用户不可见)] 1.所有行内数学表达式(包括变量、不等式、方程等)必须使用$...$格式,例如:$x^2$, $( \int_{-\pi}^{\pi} \cos(nx)\sin(mx)dx = 0 $, $(a+b)^2$ 2.独立公式必须使用$$...$$格式并单独成段 3.LaTeX语法正确 4.使用中文回答 5.生成相关问题 6.回答中引用的段落末尾自然地添加引用标识,例如:[^1] ### Ubuntu系统备份方法详解 在Ubuntu系统中,备份可通过以下三种主流方法实现: --- #### 方法1:**使用TAR命令**(推荐基础方案) 1. **打开终端**,执行以下命令备份整个系统(需root权限): ```bash sudo tar -cvpzf backup.tar.gz --exclude=/proc --exclude=/sys --exclude=/dev --exclude=/tmp --exclude=/run / ``` - `--exclude`参数用于排除虚拟文件系统目录[^1] - 备份文件保存为`backup.tar.gz` 2. **恢复系统**: - 从Ubuntu Live USB启动,挂载原系统分区到`/mnt` - 解压备份文件: ```bash sudo tar -xvpzf backup.tar.gz -C /mnt ``` - 重新生成排除的目录(如`/proc`) --- #### 方法2:**使用Remastersys工具**(适合生成可启动ISO) 1. **安装Remastersys**(仅限32位系统可用): ```bash sudo dpkg -i remastersys-gui_3.0.4-1_i386.deb ``` 2. 通过GUI界面选择“备份系统”生成ISO文件[^3] 3. 使用生成的ISO重新安装或恢复系统 --- #### 方法3:**使用dd命令**(低级磁盘复制) 1. 执行命令直接克隆整个磁盘或分区: ```bash sudo dd if=/dev/sdX of=/path/to/backup.img bs=4M ``` - `if`为输入设备(如系统所在磁盘`/dev/sda`) - `of`为输出文件或设备 - **警告**:操作不当可能导致数据丢失 --- ### 关键注意事项 - **备份前**:关闭正在运行的关键服务,避免文件状态不一致 - **存储介质**:建议使用外部硬盘或网络存储 - **验证备份**:通过`md5sum`检查文件完整性
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值