【德哥说库系列】-ASM管理Oracle 19C单实例部署

news2024/11/28 8:46:50

📢📢📢📣📣📣
哈喽!大家好,我是【IT邦德】,江湖人称jeames007,10余年DBA及大数据工作经验
一位上进心十足的【大数据领域博主】!😜😜😜
中国DBA联盟(ACDU)成员,目前服务于工业互联网
擅长主流Oracle、MySQL、PG、高斯及Greenplum运维开发,备份恢复,安装迁移,性能优化、故障应急处理等。
✨ 如果有对【数据库】感兴趣的【小可爱】,欢迎关注【IT邦德】💞💞💞
❤️❤️❤️感谢各位大可爱小可爱!❤️❤️❤️

文章目录

  • 前言
    • 📣 1.环境准备
    • 📣 2.yum安装依赖
      • ✨ 2.1 yum源的配置
      • ✨ 2.2 安装依赖
    • 📣 3. database-preinstall
    • 📣 4.目录及权限设置
    • 📣 5.环境变量
    • 📣 6.上传oracle安装包
    • 📣 7.创建GI用户
    • 📣 8.GI资源配置
    • 📣 9.绑定共享磁盘
    • 📣 10.创建GI目录
    • 📣 11.配置GI环境变量
    • 📣 12.上传GI安装包
    • 📣 13.安装 cvuqdisk
    • 📣 14.安装GI
    • 14.ASM创建磁盘组
    • 15.安装Oracle软件
    • 16.DBCA建库
    • 17.日常管理

前言

本文祥细阐述了ASM管理Oracle 19C单实例部署

📣 1.环境准备

通过虚拟机克隆来提供部署需要OEL7.9的操作系统

1.1 环境检查
[root@oel79 ~]# cat /etc/redhat-release
Red Hat Enterprise Linux Server release 7.9 (Maipo)
[root@oel79 ~]# cat /etc/oracle-release
Oracle Linux Server release 7.9
[root@oel79 ~]# df -TH
Filesystem          Type      Size  Used Avail Use% Mounted on
devtmpfs            devtmpfs  4.3G     0  4.3G   0% /dev
tmpfs               tmpfs     4.4G     0  4.4G   0% /dev/shm
tmpfs               tmpfs     4.4G   11M  4.4G   1% /run
tmpfs               tmpfs     4.4G     0  4.4G   0% /sys/fs/cgroup
/dev/mapper/ol-root ext4       43G  4.4G   36G  11% /
/dev/sda1           ext4      1.1G  213M  741M  23% /boot
/dev/mapper/ol-u01  ext4       52G   55M   49G   1% /u01
tmpfs               tmpfs     864M   29k  864M   1% /run/user/0
/dev/sr0            iso9660   4.9G  4.9G     0 100% /run/media/root/OL-7.9 Server.x86_64
[root@oel79 ~]# free -m
              total        used        free      shared  buff/cache   available
Mem:           8238         634        6916          15         687        7338
Swap:         10239           0       10239
[root@oel79 ~]# free -g
              total        used        free      shared  buff/cache   available
Mem:              8           0           6           0           0           7
Swap:             9           0           9
[root@oel79 ~]#
[root@oel79 ~]#
[root@oel79 ~]# ifconfig
ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 192.168.6.20  netmask 255.255.255.0  broadcast 192.168.6.255
        inet6 fe80::e08:b228:bbf4:4168  prefixlen 64  scopeid 0x20<link>
        ether 00:0c:29:6b:eb:f4  txqueuelen 1000  (Ethernet)
        RX packets 291  bytes 28044 (27.3 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 260  bytes 40332 (39.3 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

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 176  bytes 13512 (13.1 KiB)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 176  bytes 13512 (13.1 KiB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

virbr0: flags=4099<UP,BROADCAST,MULTICAST>  mtu 1500
        inet 192.168.122.1  netmask 255.255.255.0  broadcast 192.168.122.255
        ether 52:54:00:d9:8d:56  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


1.2 挂存储
把新添加的磁盘虚拟设备节点改成从 1: 0 开始,第二个磁盘就是 1: 1, 重复添加磁盘的操作, 20G 一个、 0.5G 七个。

##打开虚拟机的配置文件.vmx,将以下内容粘贴进去

scsi1:0.deviceType = "disk"
scsi1:1.deviceType = "disk"
scsi1:2.deviceType = "disk"
scsi1:3.deviceType = "disk"
scsi1:4.deviceType = "disk"
scsi1:5.deviceType = "disk"
scsi1:6.deviceType = "disk"
scsi1:8.deviceType = "disk"
disk.locking ="FALSE"
diskLib.dataCacheMaxSize= "0"
diskLib.dataCacheMaxReadAheadSize = "0"
diskLib.DataCacheMinReadAheadSize = "0"
diskLib.dataCachePageSize = "4096"
diskLib.maxUnsyncedWrites = "0"
disk.EnableUUID="TRUE"

[root@oel79 ~]# fdisk -l | grep dev
Disk /dev/sda: 107.4 GB, 107374182400 bytes, 209715200 sectors
/dev/sda1   *        2048     2099199     1048576   83  Linux
/dev/sda2         2099200   209715199   103808000   8e  Linux LVM
Disk /dev/sdg: 536 MB, 536870912 bytes, 1048576 sectors
Disk /dev/sdc: 536 MB, 536870912 bytes, 1048576 sectors
Disk /dev/sdb: 21.5 GB, 21474836480 bytes, 41943040 sectors
Disk /dev/sdd: 536 MB, 536870912 bytes, 1048576 sectors
Disk /dev/sdf: 536 MB, 536870912 bytes, 1048576 sectors
Disk /dev/sde: 536 MB, 536870912 bytes, 1048576 sectors
Disk /dev/sdi: 536 MB, 536870912 bytes, 1048576 sectors
Disk /dev/sdh: 536 MB, 536870912 bytes, 1048576 sectors
Disk /dev/mapper/ol-root: 42.9 GB, 42949672960 bytes, 83886080 sectors
Disk /dev/mapper/ol-swap: 10.7 GB, 10737418240 bytes, 20971520 sectors
Disk /dev/mapper/ol-u01: 52.6 GB, 52609155072 bytes, 102752256 sectors

1.3 关闭防火墙
[root@oel79 ~]# systemctl status firewalld.service
[root@oel79 ~]# systemctl stop firewalld.service
[root@oel79 ~]# systemctl disable firewalld.service

1.4 关闭selinx的安全服务
[root@oel79 ~]# cat /etc/selinux/config
修改SELINUX=enforcing为SELINUX=disabled

1.5 host解析
[root@oel79 ~]# cat /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
##新增以下内容
192.168.6.20 oel79

📣 2.yum安装依赖

✨ 2.1 yum源的配置

[root@oel79 ~]# vi /etc/yum.repos.d/local.repo

[server]
name=Linux
baseurl=file:///run/media/root/OL-7.9%20Server.x86_64
enabled=1
gpgcheck=0

✨ 2.2 安装依赖

[root@oel79 ~]# yum install compat-libcap1 ksh libaio-devel glibc-devel libstdc++-devel -y

在这里插入图片描述

📣 3. database-preinstall

## root用户下执行
[root@oel79 opt]# rpm -ivh oracle-database-preinstall-19c-1.0-1.el7.x86_64.rpm
warning: oracle-database-preinstall-19c-1.0-1.el7.x86_64.rpm: Header V3 RSA/SHA256 Signature, key ID ec551f03: NOKEY
Preparing...                          ################################# [100%]
Updating / installing...
   1:oracle-database-preinstall-19c-1.################################# [100%]
   
该 rpm会创建oracle用户、相关用户组、以及配置系统的参数
如 /etc/security/limits.d/oracle-database-preinstall-19c.conf

## 设置 oracle 口令
echo "oracle" | passwd --stdin oracle

📣 4.目录及权限设置

##创建目录
mkdir -p /u01/app/oracle/product/19.0.0/dbhome_1/
chown -R oracle:oinstall /u01
chmod -R 775 /u01

📣 5.环境变量

## 以下内容oracle用户下执行

su - oracle

vi .bash_profile
export ORACLE_SID=prod
export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=$ORACLE_BASE/product/19.0.0/dbhome_1
export PATH=$PATH:$ORACLE_HOME/bin
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/lib
export CLASSPATH=$ORACLE_HOME/JRE:ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib

##环境变量生效
source .bash_profile

📣 6.上传oracle安装包

注:软件包上传到 ORACLE_HOME 目录(oracle 用户解压)

## 校验密钥
[root@oel79 opt]# sha256sum LINUX.X64_193000_db_home.zip
ba8329c757133da313ed3b6d7f86c5ac42cd9970a28bf2e6233f3235233aa8d8  LINUX.X64_193000_db_home.zip

[oracle@oel79 ~]$ echo $ORACLE_HOME
/u01/app/oracle/product/19.0.0/dbhome_1

chown oracle:oinstall -R LINUX.X64_193000_db_home.zip
chmod 755 -R LINUX.X64_193000_db_home.zip
unzip LINUX.X64_193000_db_home.zip

📣 7.创建GI用户

## 添加组
/usr/sbin/groupadd -g 1020 asmadmin
/usr/sbin/groupadd -g 1021 asmdba
/usr/sbin/groupadd -g 1022 asmoper

## 添加grid用户
/usr/sbin/useradd -u 1102 -g oinstall -G dba,asmdba,backupdba,dgdba,kmdba,asmoper,asmadmin,racdba grid

## 改密码
echo "grid" | passwd --stdin grid

## 修改oracle用户
usermod -g oinstall -G dba,asmadmin,asmdba,asmoper,backupdba,dgdba,kmdba,oper,racdba oracle

📣 8.GI资源配置

编辑资源配置,在最后一行里面增加
vi /etc/security/limits.conf
grid soft nproc 2047
grid hard nproc 16384
grid soft nofile 1024
grid hard nofile 65536
grid soft stack 10240
grid hard stack 32768

📣 9.绑定共享磁盘

[root@oel79 ~]# ls -l /dev/sd*
brw-rw----. 1 root disk 8,   0 Sep  3 09:55 /dev/sda
brw-rw----. 1 root disk 8,   1 Sep  3 09:55 /dev/sda1
brw-rw----. 1 root disk 8,   2 Sep  3 09:55 /dev/sda2
brw-rw----. 1 root disk 8,  16 Sep  3 09:55 /dev/sdb
brw-rw----. 1 root disk 8,  32 Sep  3 09:55 /dev/sdc
brw-rw----. 1 root disk 8,  48 Sep  3 09:55 /dev/sdd
brw-rw----. 1 root disk 8,  64 Sep  3 09:55 /dev/sde
brw-rw----. 1 root disk 8,  80 Sep  3 09:55 /dev/sdf
brw-rw----. 1 root disk 8,  96 Sep  3 09:55 /dev/sdg
brw-rw----. 1 root disk 8, 112 Sep  3 09:55 /dev/sdh
brw-rw----. 1 root disk 8, 128 Sep  3 09:55 /dev/sdi


for i in b c d e f g h i; do echo "KERNEL==\"sd*[!0-9]\",ENV{DEVTYPE}==\"disk\",SUBSYSTEM==\"block\",PROGRAM==\"/usr/lib/udev/scsi_id -g -u -d\$devnode\",RESULT==\"`/lib/udev/scsi_id --whitelisted --replace-whitespace --device=/dev/sd$i`\", SYMLINK+=\"asm-disk$i\", OWNER=\"grid\", GROUP=\"asmadmin\",MODE=\"0660\"" >> /etc/udev/rules.d/99-oracle-asmdevices.rules; done;

[root@oel79 ~]# cat /etc/udev/rules.d/99-oracle-asmdevices.rules
KERNEL=="sd*[!0-9]",ENV{DEVTYPE}=="disk",SUBSYSTEM=="block",PROGRAM=="/usr/lib/udev/scsi_id -g -u -d$devnode",RESULT=="36000c29653e86c5f015ab3d2e7e9bbae", SYMLINK+="asm-diskb", OWNER="grid", GROUP="asmadmin",MODE="0660"
KERNEL=="sd*[!0-9]",ENV{DEVTYPE}=="disk",SUBSYSTEM=="block",PROGRAM=="/usr/lib/udev/scsi_id -g -u -d$devnode",RESULT=="36000c29a052769eb43d01664ca55a894", SYMLINK+="asm-diskc", OWNER="grid", GROUP="asmadmin",MODE="0660"
KERNEL=="sd*[!0-9]",ENV{DEVTYPE}=="disk",SUBSYSTEM=="block",PROGRAM=="/usr/lib/udev/scsi_id -g -u -d$devnode",RESULT=="36000c29c19465340359f4408bd2a4dff", SYMLINK+="asm-diskd", OWNER="grid", GROUP="asmadmin",MODE="0660"
KERNEL=="sd*[!0-9]",ENV{DEVTYPE}=="disk",SUBSYSTEM=="block",PROGRAM=="/usr/lib/udev/scsi_id -g -u -d$devnode",RESULT=="36000c2906dc37bda2eb23b86b441831e", SYMLINK+="asm-diske", OWNER="grid", GROUP="asmadmin",MODE="0660"
KERNEL=="sd*[!0-9]",ENV{DEVTYPE}=="disk",SUBSYSTEM=="block",PROGRAM=="/usr/lib/udev/scsi_id -g -u -d$devnode",RESULT=="36000c29b6a9e99f76a60e4c1e2c47838", SYMLINK+="asm-diskf", OWNER="grid", GROUP="asmadmin",MODE="0660"
KERNEL=="sd*[!0-9]",ENV{DEVTYPE}=="disk",SUBSYSTEM=="block",PROGRAM=="/usr/lib/udev/scsi_id -g -u -d$devnode",RESULT=="36000c29b39f1155952c12d89c5823467", SYMLINK+="asm-diskg", OWNER="grid", GROUP="asmadmin",MODE="0660"
KERNEL=="sd*[!0-9]",ENV{DEVTYPE}=="disk",SUBSYSTEM=="block",PROGRAM=="/usr/lib/udev/scsi_id -g -u -d$devnode",RESULT=="36000c297eb5d57761da1c873da5cc8e4", SYMLINK+="asm-diskh", OWNER="grid", GROUP="asmadmin",MODE="0660"
KERNEL=="sd*[!0-9]",ENV{DEVTYPE}=="disk",SUBSYSTEM=="block",PROGRAM=="/usr/lib/udev/scsi_id -g -u -d$devnode",RESULT=="36000c29a6afc8636a8162bf7f92e9bdd", SYMLINK+="asm-diski", OWNER="grid", GROUP="asmadmin",MODE="0660"


##生效
/sbin/udevadm trigger
##查看
[root@oel79 ~]# ls -l /dev/sd*
brw-rw----. 1 root disk     8,   0 Sep  3 12:19 /dev/sda
brw-rw----. 1 root disk     8,   1 Sep  3 12:19 /dev/sda1
brw-rw----. 1 root disk     8,   2 Sep  3 12:19 /dev/sda2
brw-rw----. 1 grid asmadmin 8,  16 Sep  3 12:19 /dev/sdb
brw-rw----. 1 grid asmadmin 8,  32 Sep  3 12:19 /dev/sdc
brw-rw----. 1 grid asmadmin 8,  48 Sep  3 12:19 /dev/sdd
brw-rw----. 1 grid asmadmin 8,  64 Sep  3 12:19 /dev/sde
brw-rw----. 1 grid asmadmin 8,  80 Sep  3 12:19 /dev/sdf
brw-rw----. 1 grid asmadmin 8,  96 Sep  3 12:19 /dev/sdg
brw-rw----. 1 grid asmadmin 8, 112 Sep  3 12:19 /dev/sdh
brw-rw----. 1 grid asmadmin 8, 128 Sep  3 12:19 /dev/sdi

[root@oel79 ~]# ls -l /dev/asm*
lrwxrwxrwx. 1 root root 3 Sep  3 12:19 /dev/asm-diskb -> sdb
lrwxrwxrwx. 1 root root 3 Sep  3 12:19 /dev/asm-diskc -> sdc
lrwxrwxrwx. 1 root root 3 Sep  3 12:19 /dev/asm-diskd -> sdd
lrwxrwxrwx. 1 root root 3 Sep  3 12:19 /dev/asm-diske -> sde
lrwxrwxrwx. 1 root root 3 Sep  3 12:19 /dev/asm-diskf -> sdf
lrwxrwxrwx. 1 root root 3 Sep  3 12:19 /dev/asm-diskg -> sdg
lrwxrwxrwx. 1 root root 3 Sep  3 12:19 /dev/asm-diskh -> sdh
lrwxrwxrwx. 1 root root 3 Sep  3 12:19 /dev/asm-diski -> sdi

📣 10.创建GI目录

mkdir -p /u01/app/grid/19.0.0/grid
chown -R grid:oinstall /u01/app/grid

📣 11.配置GI环境变量

##切换到 grid 用户
su - grid

vi /home/grid/.bash_profile
export ORACLE_SID=+ASM
export ORACLE_BASE=/u01/app/grid
export ORACLE_HOME=/u01/app/grid/19.0.0/grid
export PATH=$ORACLE_HOME/bin:$PATH:/usr/local/bin
umask 022

##环境变量生效
source /home/grid/.bash_profile	

📣 12.上传GI安装包

## 校验密钥

将 GI 包上传/u01/app/grid/19.0.0/grid 目录下,并解压(grid 用户)
注意: gi 包的所有者为 grid, 所属组为 oinstall

[root@oel79 opt]# cp LINUX.X64_193000_grid_home.zip /u01/app/grid/19.0.0/grid
[root@oel79 opt]# chown grid:oinstall -R /u01/app/grid/19.0.0/grid
[root@oel79 opt]# chmod 775 -R /u01/app/grid/19.0.0/grid

[grid@oel79 ~]$ cd $ORACLE_HOME
[grid@oel79 grid]$ unzip LINUX.X64_193000_grid_home.zip

📣 13.安装 cvuqdisk

[root@oel79 ~]# cd /u01/app/grid/19.0.0/grid/cv/rpm
[root@oel79 rpm]# export CVUQDISK_GRP=oinstall
[root@oel79 rpm]# rpm -ivh cvuqdisk-1.0.10-1.rpm
Preparing...                          ################################# [100%]
Updating / installing...
   1:cvuqdisk-1.0.10-1                ################################# [100%]

📣 14.安装GI

[root@oel79 ~]# su - grid
[grid@oel79 ~]$ cd $ORACLE_HOME
[grid@oel79 grid]$ echo $ORACLE_HOME
/u01/app/grid/19.0.0/grid
[grid@wl ~]$ export DISPLAY=192.168.6.1:0.0
[grid@wl grid]$ ./gridSetup.sh

##root下执行脚本
/u01/app/oraInventory/orainstRoot.sh
/u01/app/grid/19.0.0/grid/root.sh

##安装之后状态检查
[grid@oel79 grid]$ crsctl stat res -t
--------------------------------------------------------------------------------
Name           Target  State        Server                   State details
--------------------------------------------------------------------------------
Local Resources
--------------------------------------------------------------------------------
ora.DATA.dg
               ONLINE  ONLINE       oel79                    STABLE
ora.LISTENER.lsnr
               ONLINE  ONLINE       oel79                    STABLE
ora.asm
               ONLINE  ONLINE       oel79                    Started,STABLE
ora.ons
               OFFLINE OFFLINE      oel79                    STABLE
--------------------------------------------------------------------------------
Cluster Resources
--------------------------------------------------------------------------------
ora.cssd
      1        ONLINE  ONLINE       oel79                    STABLE
ora.diskmon
      1        OFFLINE OFFLINE                               STABLE
ora.evmd
      1        ONLINE  ONLINE       oel79                    STABLE
--------------------------------------------------------------------------------

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

14.ASM创建磁盘组

##创建快闪区的磁盘组以及归档的磁盘组
[grid@oel79 grid]$ asmca

在这里插入图片描述
在这里插入图片描述

15.安装Oracle软件

[root@oel79 ~]# su - oracle
[oracle@oel79 ~]$ cd $ORACLE_HOME
[oracle@oel79 dbhome_1]$ export DISPLAY=192.168.6.1:0.0
[oracle@oel79 dbhome_1]$ ./runInstaller

##root用户执行以下脚本
/u01/app/oracle/product/19.0.0/dbhome_1/root.sh

在这里插入图片描述

16.DBCA建库

[root@oel79 ~]# su - oracle
[oracle@oel79 ~]$ export DISPLAY=192.168.6.1:0.0
[oracle@oel79 ~]$ env | grep ORACLE_SID
ORACLE_SID=prod
[oracle@oel79 ~]$ dbca

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

17.日常管理

1.集群状态
[grid@oel79 ~]$ crsctl stat res -t
--------------------------------------------------------------------------------
Name           Target  State        Server                   State details
--------------------------------------------------------------------------------
Local Resources
--------------------------------------------------------------------------------
ora.ARCH.dg
               ONLINE  ONLINE       oel79                    STABLE
ora.DATA.dg
               ONLINE  ONLINE       oel79                    STABLE
ora.FRA.dg
               ONLINE  ONLINE       oel79                    STABLE
ora.LISTENER.lsnr
               ONLINE  ONLINE       oel79                    STABLE
ora.asm
               ONLINE  ONLINE       oel79                    Started,STABLE
ora.ons
               OFFLINE OFFLINE      oel79                    STABLE
--------------------------------------------------------------------------------
Cluster Resources
--------------------------------------------------------------------------------
ora.cssd
      1        ONLINE  ONLINE       oel79                    STABLE
ora.diskmon
      1        OFFLINE OFFLINE                               STABLE
ora.evmd
      1        ONLINE  ONLINE       oel79                    STABLE
ora.prod.db
      1        ONLINE  ONLINE       oel79                    Open,HOME=/u01/app/o
                                                             racle/product/19.0.0
2.数据库的状态
[oracle@oel79 ~]$ srvctl status database -d prod
Database is running.

3.启动关闭顺序
关闭:先关闭 rdbms 实例---->关闭 ASM 实例
开启:先开启 ASM 实例---->再开启 rdbms 实例

注意:重启 linux 后,ASM和RDBMS自动启动

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

垃圾回收 - 引用计数法

GC原本是一种“释放怎么都无法被引用的对象的机制”。那么人们自然而然就会想到&#xff0c;可以让所有对象事先记录下“有多少程序引用了自己”。让各对象知道自己的“人气指数”&#xff0c;从而让没有人气的对象自己消失&#xff0c;这就是引用计数法。 1、计数器 计数器表…

【Unity基础】1.项目搭建与视图编辑

【Unity基础】1.项目搭建与视图编辑 大家好&#xff0c;我是Lampard~~ 欢迎来到Unity基础系列博客&#xff0c;终于要开始写基础系列的博客了&#xff0c;前两篇的内容基本上与入门系列相同&#xff0c;如果有紧跟入门系列的同学可以直接从第三篇文章开始看 好了话不多说我们开…

Java切换到Kotlin,Crash率上升了?

前言 最近对一个Java写的老项目进行了部分重构&#xff0c;测试过程中波澜不惊&#xff0c;顺利上线后几天通过APM平台查看发现Crash率上升了&#xff0c;查看堆栈定位到NPE类型的Crash&#xff0c;大部分发生在Java调用Kotlin的函数里&#xff0c;本篇将会分析具体的场景以及…

ORB-SLAM3复现过程中遇到的问题及解决办法

在复现过程中遇到的问题的解决过程 1. 版本检查1.1 Opencv版本的检测1.2 Eigen版本的检测1.3 查看Python版本1.4 其他 2. 编译过程中遇到的问题及解决办法2.1 ./build.sh遇到的问题2.2 ./build_ros.sh遇到的问题 因为环境比较干净&#xff0c;所以遇到的问题相对少一些&#xf…

ARM 汇编基础知识

1.为什么学习汇编&#xff1f; 我们在进行嵌入式 Linux 开发的时候是绝对要掌握基本的 ARM 汇编&#xff0c;因为 Cortex-A 芯片一 上电 SP 指针还没初始化&#xff0c; C 环境还没准备好&#xff0c;所以肯定不能运行 C 代码&#xff0c;必须先用汇编语言设置好 C 环境…

【python】实现积分

借助sympy.integrate() 符号运算库&#xff0c;所以里面的exp()&#xff0c;sin()等都要使用sympy库中的函数&#xff0c;如果使用numpy库中的函数时没用的。 import sympy as sp import numpy as np x sp.symbols("x") print(sp.integrate(sp.exp(-x**2), (x, -s…

企业数据加密软件——「天锐绿盾」

「天锐绿盾」是一款企业数据加密软件&#xff0c;主要用于防止企业计算机信息被破坏、丢失和泄密。该软件采用文件过滤驱动实现透明加解密&#xff0c;对用户完全透明&#xff0c;不影响用户操作习惯。 PC访问地址&#xff1a; isite.baidu.com/site/wjz012xr/2eae091d-1b97-4…

makefile开发应用程序的一个通用模板

下面是一个通用的 Makefile 模板&#xff0c;用于开发 C 语言应用程序&#xff1a; # 编译器设置 CC gcc CFLAGS -Wall -Wextra -stdc99# 可执行文件名 TARGET your_program# 源文件和对象文件 SRCS main.c file1.c file2.c OBJS $(SRCS:.c.o)# 默认目标 all: $(TARGET)#…

buildroot修改内核防止清理重新加载办法

当你使用 Buildroot 构建 Linux 内核时&#xff0c;如果对内核文件进行了手动修改&#xff0c;重新执行 Buildroot 的构建过程将会覆盖你所做的修改。这是因为 Buildroot会根据配置重新下载、提取和编译内核。 为了避免在重新构建时覆盖你的修改&#xff0c;可以采取以下两种方…

减量时代下,伊利金领冠DTB新模式凭什么成为母婴行业“破局之道”?

穷则变&#xff0c;变则通&#xff0c;通则久。 当下&#xff0c;许多行业正在穿越不确定性周期&#xff0c;增长放缓成为常态。如何通过创新应对变局&#xff0c;进而实现长期主义&#xff0c;成为摆在所有行业和企业面前的课题。 众多行业中&#xff0c;婴配粉市场的不确定…

lv3 嵌入式开发-3 linux shell命令(文件搜索、文件处理、压缩)

目录 1 查看文件相关命令 1.1 常用命令 1.2 硬链接和软链接 2 文件搜索相关命令 2.1 查找文件命令 2.2 查找文件内容命令 2.3 其他相关命令 3 文件处理相关命令 3.1 cut 3.2 sed 过滤 3.3 awk 匹配 4 解压缩相关命令 4.1 解压缩文件的意义 4.2 解压缩相关命令 1 …

推荐个一行代码的Python可视化神器

学过Python数据分析的朋友都知道&#xff0c;在可视化的工具中&#xff0c;有很多优秀的三方库&#xff0c;比如matplotlib&#xff0c;seaborn&#xff0c;plotly&#xff0c;Boken&#xff0c;pyecharts等等。这些可视化库都有自己的特点&#xff0c;在实际应用中也广为大家使…

数据结构(Java实现)-反射、枚举以及lambda表达式

Java的反射&#xff08;reflection&#xff09;机制是在运行状态中&#xff0c;对于任意一个类&#xff0c;都能够知道这个类的所有属性和方法&#xff1b;对于任意一个对象&#xff0c;都能够调用它的任意方法和属性&#xff0c;既然能拿到那么&#xff0c;我们就可以修改部分…

内网隧道代理技术(二十一)之 CS工具自带中转技术上线不出网机器

CS工具自带上线不出网机器 如图A区域存在一台中转机器,这台机器可以出网,这种是最常见的情况。我们在渗透测试的过程中经常是拿下一台边缘机器,其有多块网卡,边缘机器可以访问内网机器,内网机器都不出网。这种情况下拿这个边缘机器做中转,就可以使用CS工具自带上线不出网…

shiro550漏洞分析

准备工作 启动该项目 可以看到没有登录时候&#xff0c;cookie中没有rememberme字段 登录时候 当账号密码输入正确时候 登录后存在该字段 shiro特征&#xff1a; 未登陆的情况下&#xff0c;请求包的cookie中没有rememberMe字段&#xff0c;返回包set-Cookie⾥也没有del…

JMeter测试工具

JMeter测试工具 1、下载地址&#xff1a; https://downloads.apache.org/jmeter/binaries/ https://downloads.apache.org/jmeter/binaries/2、启动 解压&#xff1a; 点击bin目录下的jmeter.bat就可以运行 jmeter.bat3、流控规则测试

蓝牙发展现状

目录 一、产品分类1、Bluetooth经典2、Bluetooth低能耗(LE)3、二者差异 二、出货量三、未来需要加强的方向四、技术行业细分五、学习资料1、蓝牙官网2、大神博客——于忠军 一、产品分类 1、Bluetooth经典 Bluetooth Classic无线电&#xff0c;也被称为Bluetooth 基本速率/增强…

EasyExcel导出模板实现下拉选(解决下拉超过50个限制)

学习地址&#xff1a;https://d9bp4nr5ye.feishu.cn/wiki/O3obweIbgi2Rk1ksXJncpClTnAfB站视频&#xff1a;https://www.bilibili.com/video/BV1H34y1T7Lm 先来看看最终实现效果&#xff0c;如果效果是你想要的&#xff0c;再看看实现逻辑。 EasyExcel本身是支持设置下拉校验的…

大学物理 之 安培环路定理

文章目录 前言什么是安培环路定理安培环路定理有什么作用 深入了解深入学习 前言 什么是安培环路定理 安培环路定理的物理意义在于描述了电流和磁场之间的相互作用&#xff0c;以及如何在一个封闭的回路中分析这种相互作用。 简单的来说 , 用环路定理来解决在磁场中B对任意封…

教你如何让iPhone电池更健康,不容错过的10个技巧

iPhone是一款功能强大的设备,但与许多电子产品一样,它需要一些维护才能确保正常工作。就像一艘可以永远航行的船,只要人们愿意维护它,只要你保持电池健康,你的iPhone就会继续工作。 以下是为什么维护iPhone电池至关重要,以及如何做到这一点,让你的设备使用更长时间。 …