配置服务器

参考博客

1. https://blog.csdn.net/qq_31278903/article/details/83146031

  1. https://blog.csdn.net/u014374826/article/details/134093409

  2. https://blog.csdn.net/weixin_42728126/article/details/88887350

  3. https://blog.csdn.net/Dreamhai/article/details/109764502

  4. Ubuntu 22.04 安装 NVIDIA 显卡驱动失败笔记 - 小时百科 (wuli.wiki)

  5. ubuntu20.04安装nvidia驱动真实有效


重装Ubuntu24.04系统

实验室有一台五年前的老机子,老师让我将它重新利用起来,于是我就来开始一顿捣鼓了。

1. 准备系统盘
2. 更改为U盘启动

把系统盘插入电脑中,然后重启电脑,这里需要进入bios界面更改为U盘启动,不同品牌电脑进入BIOS的快捷键不同,我们实验室这台机子使用F2进入。

  • 重新启动电脑,开机时不停地按F2键进入BIOS界面
  • 更改优先启动项为U盘最高
  • 保存更改设置,然后等待提示安装系统

BIOS是英文 "Basic Input Output System" 的缩略词,直译过来后中文名称就是 "基本输入输出系统"。其实,它是一组固化到计算机内主板上一个daoROM芯片上的程序,它保存着计算机最重要的基本输入输出的程序、系统设置信息、开机后自检程序和系统自启动程序。 其主要功能是为计算机提供最底层的、最直接的硬件设置和控制。

原文链接:https://blog.csdn.net/songyuchaoshi/article/details/109639071

3. 安装系统

我安装的是Ubuntu2024.04桌面版,因此按默认的选项一直下一步就完事,安装成功之后,拔出优盘,重启系统。

配置环境

1. 重置root密码

有一些命令或者应用需要用root身份安装,我想知道新装的Ubuntu系统中默认的root用户密码是多少?新装的系统的root密码是随机生成的,我们使用密码修改命令将其修改成熟悉的密码:

bash 复制代码
qfchen@Tanlab-Server:~$ su passwd

在安装系统的过程,我设置了一个用户名和密码,这个账号是具有管理员权限的,因此可以使用su命令。

2. 格式化其他磁盘

我用 lsblk 查看系统所有的硬盘使用情况发现这台机子的旧系统放在另一个磁盘(nvme0n1)上,于是我想把nvme0n1硬盘上的信息全部格式化掉。

ubuntu--vg--1-ubuntu--lv:重新安装的系统

ubuntu--vg-ubuntu--lv:以前的老系统(需要格式化)

然后又用 fdisk -l 命令来查看系统里面识别到的硬盘和分区的信息

这里可以用lsblk -d -o name,rota命令区分机械硬盘(hdd)和固态硬盘(ssd):

了解到磁盘基本信息之后,我们就可以将该硬盘格式化掉啦

bash 复制代码
root@server4049:~# parted /dev/nvme0n1
GNU Parted 3.6
Using /dev/nvme0n1
Welcome to GNU Parted! Type 'help' to view a list of commands.
(parted) mklabel gpt                                                      
Warning: The existing disk label on /dev/nvme0n1 will be destroyed and all data on this disk will be lost. Do you want to continue?
Yes/No? yes                                                               
Error: Partition(s) 3 on /dev/nvme0n1 have been written, but we have been unable to inform the kernel of the change, probably because it/they are in use.  As a
result, the old partition(s) will remain in use.  You should reboot now before making further changes.
Ignore/Cancel? Ignore                                                     
(parted) print                                                            
Model: WDS100T3X0C-00SJG0 (nvme)
Disk /dev/nvme0n1: 1000GB
Sector size (logical/physical): 512B/512B
Partition Table: gpt
Disk Flags: 

Number  Start  End  Size  File system  Name  Flags

(parted) mkpart primary 0 1000GB
Warning: The resulting partition is not properly aligned for best performance: 34s % 2048s != 0s
Ignore/Cancel? Ignore                                                     
Error: Partition(s) 1, 3 on /dev/nvme0n1 have been written, but we have been unable to inform the kernel of the change, probably because it/they are in use.  As a
result, the old partition(s) will remain in use.  You should reboot now before making further changes.
Ignore/Cancel? Ignore                                                     
(parted) print                                                            
Model: WDS100T3X0C-00SJG0 (nvme)
Disk /dev/nvme0n1: 1000GB
Sector size (logical/physical): 512B/512B
Partition Table: gpt
Disk Flags: 

Number  Start   End     Size    File system  Name     Flags
 1      17.4kB  1000GB  1000GB               primary

(parted) quit                                                             
Information: You may need to update /etc/fstab.
bash 复制代码
root@server4049:~# mkfs.ext4 /dev/nvme0n1
mke2fs 1.47.0 (5-Feb-2023)
/dev/nvme0n1 is apparently in use by the system; will not make a filesystem here!
root@server4049:~# dmsetup status
ubuntu--vg--1-ubuntu--lv: 0 209715200 linear 
ubuntu--vg-ubuntu--lv: 0 1738448896 linear 
ubuntu--vg-ubuntu--lv1: 0 1738448829 linear 
root@server4049:~# dmsetup remove_all
root@server4049:~# dmsetup status
ubuntu--vg--1-ubuntu--lv: 0 209715200 linear 
root@server4049:~# mkfs.ext4 /dev/nvme0n1p3
mke2fs 1.47.0 (5-Feb-2023)
/dev/nvme0n1p3 contains a LVM2_member file system
Proceed anyway? (y,N) y
Discarding device blocks: done                            
Creating filesystem with 243521536 4k blocks and 60882944 inodes
Filesystem UUID: b6e57451-0775-400b-93eb-d581a22ac075
Superblock backups stored on blocks: 
	32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208, 
	4096000, 7962624, 11239424, 20480000, 23887872, 71663616, 78675968, 
	102400000, 214990848

Allocating group tables: done                            
Writing inode tables: done                            
Creating journal (262144 blocks): done
Writing superblocks and filesystem accounting information: done    

安装nvidia驱动的教程

首先我们需要检查一下这台机器是否有GPU,使用如下命令: lspci |grep -i nvidia

发现 lspci 命令不在Linux环境中,那我们来安装一个

bash 复制代码
qfchen@Tanlab-Server:~$  lspci |grep -i nvidia
Command ' lspci' not found, did you mean:
  command 'lspci' from deb pciutils (1:3.10.0-2)
Try: sudo apt install <deb name>

根据提示信息, lspci 命令位于 pciutils 包中,因此需要安装这个包才能使用 lspci 命令。

bash 复制代码
qfchen@Tanlab-Server:~$ sudo apt install pciutils
Reading package lists... Done
Building dependency tree... Done
Reading state information... Done
pciutils is already the newest version (1:3.10.0-2build1).
pciutils set to manually installed.
The following package was automatically installed and is no longer required:
  libnvidia-egl-wayland1
Use 'sudo apt autoremove' to remove it.
0 upgraded, 0 newly installed, 0 to remove and 33 not upgraded.

然后我们使用 lspci 查看,发现有GPU:GeForce RTX 2080 Ti Rev. A

bash 复制代码
root@server4049:/home/qfchen# lspci |grep -i nvidia
01:00.0 VGA compatible controller: NVIDIA Corporation TU102 [GeForce RTX 2080 Ti Rev. A] (rev a1)
01:00.1 Audio device: NVIDIA Corporation TU102 High Definition Audio Controller (rev a1)
01:00.2 USB controller: NVIDIA Corporation TU102 USB 3.1 Host Controller (rev a1)
01:00.3 Serial bus controller: NVIDIA Corporation TU102 USB Type-C UCSI Controller (rev a1)

上述信息显示是有GPU,然后:

  • 第一步,打开终端,先用 nvidia-smi 查看一下,发现如下报错:
bash 复制代码
NVIDIA-SMI has failed because it couldn't communicate with the NVIDIA driver. 
Make sure that the latest NVIDIA driver is installed and running.

报错信息大概意思是 nvidia-smi 无法与 NVIDIA 驱动程序通信。通常情况下,这是由于 NVIDIA 驱动程序未正确安装或未加载而导致的。这个时候需要查看一下版本是否匹配,因为NVIDIA 驱动程序具有很强的版本依赖性,需要与特定的内核版本和 CUDA 版本匹配。

我们来查看是否安装完成NVIDIA 驱动程序,输入 dpkg -l | grep nvidia

  • 第二步,使用 ncvv -V检查驱动和cuda。
bash 复制代码
root@server4049:/usr/src# nvcc -V
Command 'nvcc' not found, but can be installed with:
apt install nvidia-cuda-toolkit

于是根据提示安装 apt install nvidia-cuda-toolkit,成功之后再次输入 nvcc -V显示信息如下:

bash 复制代码
root@server4049:/usr/src# nvcc -V
nvcc: NVIDIA (R) Cuda compiler driver
Copyright (c) 2005-2023 NVIDIA Corporation
Built on Fri_Jan__6_16:45:21_PST_2023
Cuda compilation tools, release 12.0, V12.0.140
Build cuda_12.0.r12.0/compiler.32267302_0

显示信息表明驱动是存在的,于是进行下一步:

  • 第三步,查看已安装驱动的版本信息
bash 复制代码
root@server4049:/usr/src# ls /usr/src | grep nvidia

没有显示任何信息,那就安装驱动呗!

首先确定 Software & Updates (桌面的Ubuntu)中的 Proprietary drivers for devices (restricted) 已经勾选

bash 复制代码
sudo apt update
sudo ubuntu-drivers list

可以自动安装系统认为合适的驱动

bash 复制代码
sudo ubuntu-drivers install --gpgpu
bash 复制代码
sudo ubuntu-drivers install nvidia:535

完成后(可能要重启)在 Software & Updates 中可以更改想要使用的驱动。


这个教程有用,倒腾了半天,用这个教程成功了,在root账号下操作。

  1. 先把之前的nvidia驱动卸载干净:
bash 复制代码
apt-get remove nvidia-*
apt-get remove "*nvidia-*"
  1. 删除旧内核
bash 复制代码
apt autoremove
  1. 在终端里输入下面的命令来查看可以选择哪些驱动
bash 复制代码
ubuntu-drivers devices
  1. 根据显示的推荐结果选一个,我选的是535版本,一般选择后面跟有recommend字样的版本
bash 复制代码
apt install nvidia-driver-535
  1. 顺利的会直接安装成功,然后再reboot以下即可生效驱动

  2. 查看一下显卡信息,安装NVIDIA Settings控制面板,在命令行打开控制面板或者在启动器内找到控制面板图标,打开后就可以查看显卡信息啦!

bash 复制代码
apt install nvidia-settings
nvidia-settings

结果如下所示:


后面的命令就是成功安装好 驱动之后,使用的一些基础命令查看系统信息

  • uname命令
bash 复制代码
qfchen@Tanlab-Server:~$ uname --help
Usage: uname [OPTION]...
Print certain system information.  With no OPTION, same as -s.

  -a, --all                print all information, in the following order,
                             except omit -p and -i if unknown:
  -s, --kernel-name        print the kernel name
  -n, --nodename           print the network node hostname
  -r, --kernel-release     print the kernel release
  -v, --kernel-version     print the kernel version
  -m, --machine            print the machine hardware name
  -p, --processor          print the processor type (non-portable)
  -i, --hardware-platform  print the hardware platform (non-portable)
  -o, --operating-system   print the operating system
      --help        display this help and exit
      --version     output version information and exit
  • Linux查看当前使用的内核版本
bash 复制代码
qfchen@Tanlab-Server:~$ uname -r
6.8.0-38-generic
  • Linux查看当前操作系统的内核信息
bash 复制代码
qfchen@Tanlab-Server:~$ uname -a
Linux Tanlab-Server 6.8.0-38-generic #38-Ubuntu SMP PREEMPT_DYNAMIC Fri Jun  7 15:25:01 UTC 2024 x86_64 x86_64 x86_64 GNU/Linux
  • Linux查看版本当前操作系统发行版信息
bash 复制代码
qfchen@Tanlab-Server:~$ cat /etc/issue 
Ubuntu 24.04 LTS \n \l
  • Linux查看cpu相关信息,包括型号、主频、内核信息等
bash 复制代码
qfchen@Tanlab-Server:~$ cat /proc/cpuinfo
  • Ubuntu中查看主机有多少个核
bash 复制代码
qfchen@Tanlab-Server:~$ cat /proc/cpuinfo | grep processor | wc -l
20
qfchen@Tanlab-Server:~$ nproc
20
  • 查看主机名称
bash 复制代码
qfchen@Tanlab-Server:~$ hostname
Tanlab-Server
  • 查看网络信息
bash 复制代码
qfchen@Tanlab-Server:~$ ifconfig
enp4s0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 10.16.27.223  netmask 255.255.128.0  broadcast 10.16.127.255
        inet6 fe80::d65d:64ff:fed1:f45d  prefixlen 64  scopeid 0x20<link>
        inet6 2001:da8:201d:1107::e562  prefixlen 128  scopeid 0x0<global>
        ether d4:5d:64:d1:f4:5d  txqueuelen 1000  (Ethernet)
        RX packets 2144728  bytes 3161595289 (3.1 GB)
        RX errors 0  dropped 9198  overruns 0  frame 0
        TX packets 958093  bytes 91054742 (91.0 MB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
        device memory 0xa5100000-a51fffff  

lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>
        loop  txqueuelen 1000  (Local Loopback)
        RX packets 1899  bytes 414234 (414.2 KB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 1899  bytes 414234 (414.2 KB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

wlo1: flags=4099<UP,BROADCAST,MULTICAST>  mtu 1500
        ether 04:33:c2:01:53:ec  txqueuelen 1000  (Ethernet)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

环境配置着配置着发现有线网卡(enp4s0)掉了,兵来将挡水来土掩,我们来启动它,root账号操作。

bash 复制代码
nmcli networking off
nmcli networking on

然后我们就会发现桌面版Ubuntu右上角的网络图标亮了,撒花撒花撒花。

接下来就是给其他小伙伴分配账号啦,大家一起愉快的玩耍。过程很曲折,结果还是算是好的,又巩固了一遍之前学的知识。

bash 复制代码
adduser test
相关推荐
筱小虾米1 小时前
解决SSL VPN客户端一直提示无法连接服务器的问题
运维·服务器
dntktop3 小时前
内嵌编辑器+AI助手,Wave Terminal打造终端新体验
运维
kaiyuanheshang5 小时前
docker 中的entrypoint和cmd指令
运维·docker·容器·cmd·entrypoint
wanhengwangluo6 小时前
裸金属服务器能够帮助企业解决哪些问题?
运维·服务器
Python私教6 小时前
除了 Docker,还有哪些类似的容器技术?
运维·docker·容器
titxixYY6 小时前
SElinux
linux·运维·服务器
聚名网7 小时前
手机无法连接服务器1302什么意思?
运维·服务器·智能手机
代码欢乐豆8 小时前
软件工程第13章小测
服务器·前端·数据库·软件工程
望获linux9 小时前
在 ARM 平台上如何实现Linux系统的1秒启动
linux·服务器·开发语言·数据库·操作系统·嵌入式操作系统·arm平台
先天打工圣体的男人9 小时前
Linux中安装InfluxDB
linux·运维·服务器