[...]blog:locate 命令:文件查找命令 - 灵魂信息 (soulio.top)[...]
首页
留言
统计
友链
归档
关于
Search
1
typecho博客-SEO优化-永久链接设置-伪静态
88 阅读
2
搭建网站的三种方式:家庭服务器、云服务器、serv00免费服务器
60 阅读
3
typecho主题和插件
52 阅读
4
DNF:包管理器
51 阅读
5
Homebrew:包管理器
43 阅读
网站搭建
Linux命令详解
登录
Search
标签搜索
Linux命令
serv00
Linux
网站搭建
typecho
Excel
正则表达式
PVE
mdx
soulio
累计撰写
146
篇文章
累计收到
2
条评论
今日撰写
0
篇文章
首页
栏目
网站搭建
Linux命令详解
页面
留言
统计
友链
归档
关于
用户登录
登录
搜索到
4
篇与
的结果
2024-09-27
bench.sh:Linux服务器基准测试
简介bench.sh 是一个 Linux 系统性能基准测试工具。它的测试结果如下图:给出服务器的整体配置信息,IO 性能,网络性能。很多人使用它测试 vps 性能。一键运行服务器在国外可以使用以下命令运行测试wget -qO- bench.sh | bash 复制脚本到本地运行服务器在国内只能从 github 复制脚本到本地运行。脚本内容已经贴到下面:复制代码块,保存到 bench.sh 文件中,chmod +x 赋权, ./bench.sh 运行。#!/usr/bin/env bash # # # Copyright (C) 2015 - 2023 Teddysun <
[email protected]
> # Thanks: LookBack <
[email protected]
> # URL: https://teddysun.com/444.html # https://github.com/teddysun/across/blob/master/bench.sh # trap _exit INT QUIT TERM _red() { printf '\033[0;31;31m%b\033[0m' "$1" } _green() { printf '\033[0;31;32m%b\033[0m' "$1" } _yellow() { printf '\033[0;31;33m%b\033[0m' "$1" } _blue() { printf '\033[0;31;36m%b\033[0m' "$1" } _exists() { local cmd="$1" if eval type type >/dev/null 2>&1; then eval type "$cmd" >/dev/null 2>&1 elif command >/dev/null 2>&1; then command -v "$cmd" >/dev/null 2>&1 else which "$cmd" >/dev/null 2>&1 fi local rt=$? return ${rt} } _exit() { _red "\nThe script has been terminated. Cleaning up files...\n" # clean up rm -fr speedtest.tgz speedtest-cli benchtest_* exit 1 } get_opsy() { [ -f /etc/redhat-release ] && awk '{print $0}' /etc/redhat-release && return [ -f /etc/os-release ] && awk -F'[= "]' '/PRETTY_NAME/{print $3,$4,$5}' /etc/os-release && return [ -f /etc/lsb-release ] && awk -F'[="]+' '/DESCRIPTION/{print $2}' /etc/lsb-release && return } next() { printf "%-70s\n" "-" | sed 's/\s/-/g' } speed_test() { local nodeName="$2" if [ -z "$1" ];then ./speedtest-cli/speedtest --progress=no --accept-license --accept-gdpr >./speedtest-cli/speedtest.log 2>&1 else ./speedtest-cli/speedtest --progress=no --server-id="$1" --accept-license --accept-gdpr >./speedtest-cli/speedtest.log 2>&1 fi if [ $? -eq 0 ]; then local dl_speed up_speed latency dl_speed=$(awk '/Download/{print $3" "$4}' ./speedtest-cli/speedtest.log) up_speed=$(awk '/Upload/{print $3" "$4}' ./speedtest-cli/speedtest.log) latency=$(awk '/Latency/{print $3" "$4}' ./speedtest-cli/speedtest.log) if [[ -n "${dl_speed}" && -n "${up_speed}" && -n "${latency}" ]]; then printf "\033[0;33m%-18s\033[0;32m%-18s\033[0;31m%-20s\033[0;36m%-12s\033[0m\n" " ${nodeName}" "${up_speed}" "${dl_speed}" "${latency}" fi fi } speed() { speed_test '' 'Speedtest.net' speed_test '21541' 'Los Angeles, US' speed_test '43860' 'Dallas, US' speed_test '40879' 'Montreal, CA' speed_test '24215' 'Paris, FR' speed_test '28922' 'Amsterdam, NL' speed_test '24447' 'Shanghai, CN' speed_test '5530' 'Chongqing, CN' speed_test '60572' 'Guangzhou, CN' speed_test '32155' 'Hongkong, CN' speed_test '23647' 'Mumbai, IN' speed_test '13623' 'Singapore, SG' speed_test '21569' 'Tokyo, JP' } io_test() { (LANG=C dd if=/dev/zero of=benchtest_$$ bs=512k count="$1" conv=fdatasync && rm -f benchtest_$$) 2>&1 | awk -F '[,,]' '{io=$NF} END { print io}' | sed 's/^[ \t]*//;s/[ \t]*$//' } calc_size() { local raw=$1 local total_size=0 local num=1 local unit="KB" if ! [[ ${raw} =~ ^[0-9]+$ ]]; then echo "" return fi if [ "${raw}" -ge 1073741824 ]; then num=1073741824 unit="TB" elif [ "${raw}" -ge 1048576 ]; then num=1048576 unit="GB" elif [ "${raw}" -ge 1024 ]; then num=1024 unit="MB" elif [ "${raw}" -eq 0 ]; then echo "${total_size}" return fi total_size=$(awk 'BEGIN{printf "%.1f", '"$raw"' / '$num'}') echo "${total_size} ${unit}" } # since calc_size converts kilobyte to MB, GB and TB # to_kibyte converts zfs size from bytes to kilobyte to_kibyte() { local raw=$1 awk 'BEGIN{printf "%.0f", '"$raw"' / 1024}' } calc_sum() { local arr=("$@") local s s=0 for i in "${arr[@]}"; do s=$((s + i)) done echo ${s} } check_virt() { _exists "dmesg" && virtualx="$(dmesg 2>/dev/null)" if _exists "dmidecode"; then sys_manu="$(dmidecode -s system-manufacturer 2>/dev/null)" sys_product="$(dmidecode -s system-product-name 2>/dev/null)" sys_ver="$(dmidecode -s system-version 2>/dev/null)" else sys_manu="" sys_product="" sys_ver="" fi if grep -qa docker /proc/1/cgroup; then virt="Docker" elif grep -qa lxc /proc/1/cgroup; then virt="LXC" elif grep -qa container=lxc /proc/1/environ; then virt="LXC" elif [[ -f /proc/user_beancounters ]]; then virt="OpenVZ" elif [[ "${virtualx}" == *kvm-clock* ]]; then virt="KVM" elif [[ "${sys_product}" == *KVM* ]]; then virt="KVM" elif [[ "${sys_manu}" == *QEMU* ]]; then virt="KVM" elif [[ "${cname}" == *KVM* ]]; then virt="KVM" elif [[ "${cname}" == *QEMU* ]]; then virt="KVM" elif [[ "${virtualx}" == *"VMware Virtual Platform"* ]]; then virt="VMware" elif [[ "${sys_product}" == *"VMware Virtual Platform"* ]]; then virt="VMware" elif [[ "${virtualx}" == *"Parallels Software International"* ]]; then virt="Parallels" elif [[ "${virtualx}" == *VirtualBox* ]]; then virt="VirtualBox" elif [[ -e /proc/xen ]]; then if grep -q "control_d" "/proc/xen/capabilities" 2>/dev/null; then virt="Xen-Dom0" else virt="Xen-DomU" fi elif [ -f "/sys/hypervisor/type" ] && grep -q "xen" "/sys/hypervisor/type"; then virt="Xen" elif [[ "${sys_manu}" == *"Microsoft Corporation"* ]]; then if [[ "${sys_product}" == *"Virtual Machine"* ]]; then if [[ "${sys_ver}" == *"7.0"* || "${sys_ver}" == *"Hyper-V" ]]; then virt="Hyper-V" else virt="Microsoft Virtual Machine" fi fi else virt="Dedicated" fi } ipv4_info() { local org city country region org="$(wget -q -T10 -O- ipinfo.io/org)" city="$(wget -q -T10 -O- ipinfo.io/city)" country="$(wget -q -T10 -O- ipinfo.io/country)" region="$(wget -q -T10 -O- ipinfo.io/region)" if [[ -n "${org}" ]]; then echo " Organization : $(_blue "${org}")" fi if [[ -n "${city}" && -n "${country}" ]]; then echo " Location : $(_blue "${city} / ${country}")" fi if [[ -n "${region}" ]]; then echo " Region : $(_yellow "${region}")" fi if [[ -z "${org}" ]]; then echo " Region : $(_red "No ISP detected")" fi } install_speedtest() { if [ ! -e "./speedtest-cli/speedtest" ]; then sys_bit="" local sysarch sysarch="$(uname -m)" if [ "${sysarch}" = "unknown" ] || [ "${sysarch}" = "" ]; then sysarch="$(arch)" fi if [ "${sysarch}" = "x86_64" ]; then sys_bit="x86_64" fi if [ "${sysarch}" = "i386" ] || [ "${sysarch}" = "i686" ]; then sys_bit="i386" fi if [ "${sysarch}" = "armv8" ] || [ "${sysarch}" = "armv8l" ] || [ "${sysarch}" = "aarch64" ] || [ "${sysarch}" = "arm64" ]; then sys_bit="aarch64" fi if [ "${sysarch}" = "armv7" ] || [ "${sysarch}" = "armv7l" ]; then sys_bit="armhf" fi if [ "${sysarch}" = "armv6" ]; then sys_bit="armel" fi [ -z "${sys_bit}" ] && _red "Error: Unsupported system architecture (${sysarch}).\n" && exit 1 url1="https://install.speedtest.net/app/cli/ookla-speedtest-1.2.0-linux-${sys_bit}.tgz" url2="https://dl.lamp.sh/files/ookla-speedtest-1.2.0-linux-${sys_bit}.tgz" if ! wget --no-check-certificate -q -T10 -O speedtest.tgz ${url1}; then if ! wget --no-check-certificate -q -T10 -O speedtest.tgz ${url2}; then _red "Error: Failed to download speedtest-cli.\n" && exit 1 fi fi mkdir -p speedtest-cli && tar zxf speedtest.tgz -C ./speedtest-cli && chmod +x ./speedtest-cli/speedtest rm -f speedtest.tgz fi printf "%-18s%-18s%-20s%-12s\n" " Node Name" "Upload Speed" "Download Speed" "Latency" } print_intro() { echo "-------------------- A Bench.sh Script By Teddysun -------------------" echo " Version : $(_green v2023-10-15)" echo " Usage : $(_red "wget -qO- bench.sh | bash")" } # Get System information get_system_info() { cname=$(awk -F: '/model name/ {name=$2} END {print name}' /proc/cpuinfo | sed 's/^[ \t]*//;s/[ \t]*$//') cores=$(awk -F: '/^processor/ {core++} END {print core}' /proc/cpuinfo) freq=$(awk -F'[ :]' '/cpu MHz/ {print $4;exit}' /proc/cpuinfo) ccache=$(awk -F: '/cache size/ {cache=$2} END {print cache}' /proc/cpuinfo | sed 's/^[ \t]*//;s/[ \t]*$//') cpu_aes=$(grep -i 'aes' /proc/cpuinfo) cpu_virt=$(grep -Ei 'vmx|svm' /proc/cpuinfo) tram=$( LANG=C free | awk '/Mem/ {print $2}' ) tram=$(calc_size "$tram") uram=$( LANG=C free | awk '/Mem/ {print $3}' ) uram=$(calc_size "$uram") swap=$( LANG=C free | awk '/Swap/ {print $2}' ) swap=$(calc_size "$swap") uswap=$( LANG=C free | awk '/Swap/ {print $3}' ) uswap=$(calc_size "$uswap") up=$(awk '{a=$1/86400;b=($1%86400)/3600;c=($1%3600)/60} {printf("%d days, %d hour %d min\n",a,b,c)}' /proc/uptime) if _exists "w"; then load=$( LANG=C w | head -1 | awk -F'load average:' '{print $2}' | sed 's/^[ \t]*//;s/[ \t]*$//' ) elif _exists "uptime"; then load=$( LANG=C uptime | head -1 | awk -F'load average:' '{print $2}' | sed 's/^[ \t]*//;s/[ \t]*$//' ) fi opsy=$(get_opsy) arch=$(uname -m) if _exists "getconf"; then lbit=$(getconf LONG_BIT) else echo "${arch}" | grep -q "64" && lbit="64" || lbit="32" fi kern=$(uname -r) in_kernel_no_swap_total_size=$( LANG=C df -t simfs -t ext2 -t ext3 -t ext4 -t btrfs -t xfs -t vfat -t ntfs --total 2>/dev/null | grep total | awk '{ print $2 }' ) swap_total_size=$(free -k | grep Swap | awk '{print $2}') zfs_total_size=$(to_kibyte "$(calc_sum "$(zpool list -o size -Hp 2> /dev/null)")") disk_total_size=$(calc_size $((swap_total_size + in_kernel_no_swap_total_size + zfs_total_size))) in_kernel_no_swap_used_size=$( LANG=C df -t simfs -t ext2 -t ext3 -t ext4 -t btrfs -t xfs -t vfat -t ntfs --total 2>/dev/null | grep total | awk '{ print $3 }' ) swap_used_size=$(free -k | grep Swap | awk '{print $3}') zfs_used_size=$(to_kibyte "$(calc_sum "$(zpool list -o allocated -Hp 2> /dev/null)")") disk_used_size=$(calc_size $((swap_used_size + in_kernel_no_swap_used_size + zfs_used_size))) tcpctrl=$(sysctl net.ipv4.tcp_congestion_control | awk -F ' ' '{print $3}') } # Print System information print_system_info() { if [ -n "$cname" ]; then echo " CPU Model : $(_blue "$cname")" else echo " CPU Model : $(_blue "CPU model not detected")" fi if [ -n "$freq" ]; then echo " CPU Cores : $(_blue "$cores @ $freq MHz")" else echo " CPU Cores : $(_blue "$cores")" fi if [ -n "$ccache" ]; then echo " CPU Cache : $(_blue "$ccache")" fi if [ -n "$cpu_aes" ]; then echo " AES-NI : $(_green "\xe2\x9c\x93 Enabled")" else echo " AES-NI : $(_red "\xe2\x9c\x97 Disabled")" fi if [ -n "$cpu_virt" ]; then echo " VM-x/AMD-V : $(_green "\xe2\x9c\x93 Enabled")" else echo " VM-x/AMD-V : $(_red "\xe2\x9c\x97 Disabled")" fi echo " Total Disk : $(_yellow "$disk_total_size") $(_blue "($disk_used_size Used)")" echo " Total Mem : $(_yellow "$tram") $(_blue "($uram Used)")" if [ "$swap" != "0" ]; then echo " Total Swap : $(_blue "$swap ($uswap Used)")" fi echo " System uptime : $(_blue "$up")" echo " Load average : $(_blue "$load")" echo " OS : $(_blue "$opsy")" echo " Arch : $(_blue "$arch ($lbit Bit)")" echo " Kernel : $(_blue "$kern")" echo " TCP CC : $(_yellow "$tcpctrl")" echo " Virtualization : $(_blue "$virt")" echo " IPv4/IPv6 : $online" } print_io_test() { freespace=$(df -m . | awk 'NR==2 {print $4}') if [ -z "${freespace}" ]; then freespace=$(df -m . | awk 'NR==3 {print $3}') fi if [ "${freespace}" -gt 1024 ]; then writemb=2048 io1=$(io_test ${writemb}) echo " I/O Speed(1st run) : $(_yellow "$io1")" io2=$(io_test ${writemb}) echo " I/O Speed(2nd run) : $(_yellow "$io2")" io3=$(io_test ${writemb}) echo " I/O Speed(3rd run) : $(_yellow "$io3")" ioraw1=$(echo "$io1" | awk 'NR==1 {print $1}') [[ "$(echo "$io1" | awk 'NR==1 {print $2}')" == "GB/s" ]] && ioraw1=$(awk 'BEGIN{print '"$ioraw1"' * 1024}') ioraw2=$(echo "$io2" | awk 'NR==1 {print $1}') [[ "$(echo "$io2" | awk 'NR==1 {print $2}')" == "GB/s" ]] && ioraw2=$(awk 'BEGIN{print '"$ioraw2"' * 1024}') ioraw3=$(echo "$io3" | awk 'NR==1 {print $1}') [[ "$(echo "$io3" | awk 'NR==1 {print $2}')" == "GB/s" ]] && ioraw3=$(awk 'BEGIN{print '"$ioraw3"' * 1024}') ioall=$(awk 'BEGIN{print '"$ioraw1"' + '"$ioraw2"' + '"$ioraw3"'}') ioavg=$(awk 'BEGIN{printf "%.1f", '"$ioall"' / 3}') echo " I/O Speed(average) : $(_yellow "$ioavg MB/s")" else echo " $(_red "Not enough space for I/O Speed test!")" fi } print_end_time() { end_time=$(date +%s) time=$((end_time - start_time)) if [ ${time} -gt 60 ]; then min=$((time / 60)) sec=$((time % 60)) echo " Finished in : ${min} min ${sec} sec" else echo " Finished in : ${time} sec" fi date_time=$(date '+%Y-%m-%d %H:%M:%S %Z') echo " Timestamp : $date_time" } ! _exists "wget" && _red "Error: wget command not found.\n" && exit 1 ! _exists "free" && _red "Error: free command not found.\n" && exit 1 # check for curl/wget _exists "curl" && local_curl=true # test if the host has IPv4/IPv6 connectivity [[ -n ${local_curl} ]] && ip_check_cmd="curl -s -m 4" || ip_check_cmd="wget -qO- -T 4" ipv4_check=$( (ping -4 -c 1 -W 4 ipv4.google.com >/dev/null 2>&1 && echo true) || ${ip_check_cmd} -4 icanhazip.com 2> /dev/null) ipv6_check=$( (ping -6 -c 1 -W 4 ipv6.google.com >/dev/null 2>&1 && echo true) || ${ip_check_cmd} -6 icanhazip.com 2> /dev/null) if [[ -z "$ipv4_check" && -z "$ipv6_check" ]]; then _yellow "Warning: Both IPv4 and IPv6 connectivity were not detected.\n" fi [[ -z "$ipv4_check" ]] && online="$(_red "\xe2\x9c\x97 Offline")" || online="$(_green "\xe2\x9c\x93 Online")" [[ -z "$ipv6_check" ]] && online+=" / $(_red "\xe2\x9c\x97 Offline")" || online+=" / $(_green "\xe2\x9c\x93 Online")" start_time=$(date +%s) get_system_info check_virt clear print_intro next print_system_info ipv4_info next print_io_test next install_speedtest && speed && rm -fr speedtest-cli next print_end_time next
2024年09月27日
3 阅读
0 评论
0 点赞
2024-09-26
WSL不止命令行-启动带图形界面的软件
起因我们都知道 wsl 启动后就死一个纯命令行终端,一直以来我都是使用纯命令行工具管理Linux的。今天看到网上有人在 wsl 中启动带图形界面的软件。没错,就是在wsl中启动带有图形界面的Linux软件。比如下面这个编辑器。出于好奇,我就体验了一番,并写下这篇笔记。安装gnome-terminalgnome-terminal 是一个图形界面的文本编辑器,通过以下命令安装sudo apt update sudo apt install gnome-terminal -y 启动报错报错信息:# Error constructing proxy for org.gnome.Terminal:/org/gnome/Terminal/Factory0: Could not connect: 没有那个文件或目录上网搜索然后在网上去搜索解决,试了几个方案都不行。成功启动此时想起来在 Linux 中很多正常操作到了 wsl 中都要使用 sudo 提权才能运行。sudo gnome-terminal 加上 sudo 果然正常启动了。中文乱码-缺少字体本来wsl已经配置了中文环境但是 gnome-ternimal 中文依然乱码原因是缺少字体复制字符复制字体 - win11系统sudo mkdir -p /usr/share/fonts/windows11 sudo cp /mnt/c/Windows/Fonts/* /usr/share/fonts/windows11 再次打开就正常显示中文了低分辨率窗口分辨率比较低,锯齿感明显。此时已经不想再去搞分辨率的问题了,Linux图形界面一直都是踩过一个坑还会有另一个坑等待你。命令行就是最好的选择,最佳的体验。个人感受Windows+SSH才是Linux用户体验的天花板。你可以在Windows终端、第三方客户端、vscode中通过SSH连接Linux。
2024年09月26日
17 阅读
0 评论
0 点赞
2024-09-22
linux如何启用ipv6随机地址
简介在 IPv6 中,临时随机地址(Temporary IPv6 Address)是一种为了提高隐私和安全而设计的功能。通常,默认的 IPv6 地址是基于设备的 MAC 地址生成的,容易导致跟踪和识别设备。启用临时 IPv6 地址可以避免这个问题,因为临时地址会定期变化,不易被长期跟踪。工作原理 SLAAC(无状态地址自动配置) :默认情况下,设备使用 SLAAC 生成 IPv6 地址,结合了网络前缀和设备的接口标识符(通常基于 MAC 地址)。临时地址是 SLAAC 的扩展,用于生成随机的接口标识符。 临时地址会定期生成,并且会有一个有限的有效期。在该有效期内,地址用于外部通信。有效期过后,地址将不再使用并生成新的临时地址。 启用临时随机 IPv6 地址方法 1:修改 sysctl 配置 编辑 sysctl 配置文件:sudo nano /etc/sysctl.conf 添加以下配置行,启用临时 IPv6 地址:net.ipv6.conf.all.use_tempaddr=2 net.ipv6.conf.default.use_tempaddr=2 0: 禁用临时地址。 1: 启用临时地址,但系统默认会使用永久地址进行通信。 2: 强制使用临时地址进行外部通信。 保存文件并退出编辑器后,运行以下命令使更改生效:sudo sysctl -p 方法 2:通过命令行临时启用如果不希望永久更改配置,也可以通过命令行临时启用临时地址(仅在当前会话有效):sudo sysctl -w net.ipv6.conf.all.use_tempaddr=2 sudo sysctl -w net.ipv6.conf.default.use_tempaddr=2 验证是否启用了临时地址可以通过 ip 或 ifconfig 命令查看网络接口的 IPv6 地址,检查是否已经分配了一个临时地址。使用以下命令查看接口地址:ip a 查找带有 temporary 或 dynamic 标识的 IPv6 地址。例如:inet6 2001:db8::1234/64 scope global temporary dynamic 这表示系统已经分配了临时 IPv6 地址。临时 IPv6 地址的有效期临时地址有一个“优先使用时间”和一个“有效时间”。在优先时间内,系统会优先使用该地址进行通信。一旦优先时间过期,地址仍然有效但不再用于新连接,直到有效时间结束后地址被废弃。系统将自动生成新地址替代它。手动刷新或生成新地址如果需要手动生成新的临时 IPv6 地址,可以重启网络接口:sudo ip link set dev <接口名> down sudo ip link set dev <接口名> up 例如,对于 eth0 接口:sudo ip link set dev eth0 down sudo ip link set dev eth0 up 总结:临时 IPv6 地址是提高隐私和安全的有效方式。通过启用 use_tempaddr 参数,你的设备可以使用随机生成的临时地址来进行网络通信,避免基于 MAC 地址的跟踪。
2024年09月22日
6 阅读
0 评论
0 点赞
2024-09-22
不同的ipv6地址的用途
查看地址使用 ip a 命令查看 ip 地址 inet6 2409:5469:e5d4:0662:dd5c:a5aa:a929:d/128 scope global dynamic noprefixroute valid_lft 7077sec preferred_lft 3477sec inet6 2409:3a66:5832:23d7:8eb3:a9ef:8ea5:797d/64 scope global temporary deprecated dynamic valid_lft 6932sec preferred_lft 0sec inet6 2409:0019:7c37:61ef:a0b6:beb2:36f4:393b/64 scope global temporary deprecated dynamic valid_lft 6932sec preferred_lft 0sec inet6 2409:3c4f:f80f:67e2:ac72:69ed:5941:7494/64 scope global temporary deprecated dynamic valid_lft 6932sec preferred_lft 0sec inet6 2409:4286:e17a:a006:6b6d:927e:4cb6:1a7b/64 scope global dynamic mngtmpaddr noprefixroute valid_lft 6932sec preferred_lft 3332sec inet6 fe80::1a2b:3c4d:5e6f:7g8h/64 scope link noprefixroute valid_lft forever preferred_lft forever 以下是不同 ipv6 地址的含义:公网地址地址 1: inet6 2409:5469:e5d4:0662:dd5c:a5aa:a929:d/128 scope global dynamic noprefixroute valid_lft 7077sec preferred_lft 3477sec 前缀长度:/128(表示该地址是唯一的,不属于子网) scope global:这是一个全球范围的地址,可以在互联网上使用。 dynamic:动态分配,可能通过 DHCPv6 或 SLAAC 获取。 noprefixroute:表示系统不会自动为该地址添加路由前缀,需要手动配置路由。路由可以暂时忽略,默认情况下它不会影响你上网、搭建网络服务。 valid_lft 7077sec:该地址在未来 7077 秒内有效。 preferred_lft 3477sec:在未来 3477 秒内,该地址是首选的,优先用于新的连接。 用途:该地址是一个唯一的全球范围的 IPv6 地址,适合用于与外部网络的通信,但不会自动配置路由(需手动管理)。在 preferred_lft 到期前,系统会优先使用该地址建立连接。 默认地址:在搭建 web 服务默认时系统默认使用的这个地址。 安全隐患:会暴露局域网中其他 ipv6 设备的地址,因为 DHCP 是连号分发的。尤其在家庭网络中,千万不要使用这个地址。 随机公网地址地址 2, 3, 4(过期): inet6 2409:3a66:5832:23d7:8eb3:a9ef:8ea5:797d/64 scope global temporary deprecated dynamic valid_lft 6932sec preferred_lft 0sec inet6 2409:0019:7c37:61ef:a0b6:beb2:36f4:393b/64 scope global temporary deprecated dynamic valid_lft 6932sec preferred_lft 0sec inet6 2409:3c4f:f80f:67e2:ac72:69ed:5941:7494/64 scope global temporary deprecated dynamic valid_lft 6932sec preferred_lft 0sec 前缀长度:/64,表示属于一个子网,可以用于同子网内的通信。 scope global:全球范围的地址,可路由到互联网。 temporary:这是一个临时地址,主要用于隐私保护。 deprecated:该地址已被弃用,不再用于新连接,但仍可用于现有连接。 dynamic:动态分配,通常通过 SLAAC 或 DHCPv6 获取。 valid_lft 6932sec:在未来 6932 秒内仍然有效。 preferred_lft 0sec:该地址的优先生命周期已过期,不再用于新的连接。 用途:这几个地址是临时的全球范围地址,主要用于隐私保护功能,避免设备长期使用同一地址进行通信。由于这些地址已过期(deprecated),它们不会被用于新的连接,但现有连接仍然可以继续使用,直到 valid_lft 到期。过期:没有价值了。地址 5(生效中): inet6 2409:4286:e17a:a006:6b6d:927e:4cb6:1a7b/64 scope global dynamic mngtmpaddr noprefixroute valid_lft 6932sec preferred_lft 3332sec 前缀长度:/64,表示属于一个子网。 scope global:全球范围的地址,可以路由到互联网。 dynamic:动态分配。 mngtmpaddr:由隐私扩展生成的临时地址,通常用于防止设备跟踪,属于隐私地址。 noprefixroute:没有自动配置路由,路由需要手动管理。 valid_lft 6932sec:该地址在 6932 秒内仍然有效。 preferred_lft 3332sec:在 3332 秒内是优选地址。 用途:这是一个动态分配的全球范围的临时隐私地址,用于保护隐私。它不会自动配置路由,因此需要手动管理。它的优先生命周期还未过期,设备在新连接时会优先使用该地址。推荐地址:推荐使用这个地址搭建网络服务,避免暴露局域网中其他设备的Ipv6地址。链路本地地址链路本地地址(Link-Local Address)用于本地链路上的通信,只能在同一个网络段(链路)内使用,不能通过路由器转发。地址 6(本地): inet6 fe80::1a2b:3c4d:5e6f:7g8h/64 scope link noprefixroute valid_lft forever preferred_lft forever 前缀长度:/64,表示属于一个链路本地子网。 scope link:链路本地地址,只能在本地链路上有效,无法用于互联网通信。 noprefixroute:没有自动配置路由。 valid_lft forever:该地址永久有效。 preferred_lft forever:该地址是永久优选的。 用途:链路本地地址用于本地设备之间的直接通信,通常用于邻居发现协议(NDP)、自动配置或网络调试。它只能在本地链路内使用,无法进行全局路由,也无法访问互联网。
2024年09月22日
6 阅读
0 评论
0 点赞