位置: 编程技术 - 正文

Linux阵列 RAID详解(linux做raid10)

编辑:rootadmin

推荐整理分享Linux阵列 RAID详解(linux做raid10),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:linux_raid_member,linux磁盘raid,linux raid partition,linux raid1,linux实现raid,linux实现raid,linux raid1,linux_raid_member,内容如对您有帮助,希望把文章链接给更多的朋友!

主要内容:(笔记总结--会不定时补充、修改,如有错误,欢迎指正探讨)

一、 RAID详解 二、 mdadm工具介绍 三、 创建一个RAID的基本过程 四、 磁盘阵列的管理 五、 RAID优化

RAID详解:

描述:RAID:(Redundant Array of indenpensive Disk) 独立磁盘冗余阵列: 磁盘阵列是把多个磁盘组成一个阵列,当作单一磁盘使用,它将数据以分段(striping)的方式储存在不同的磁盘中,存取数据时,阵列中的相关磁盘一起动作,大幅减低数据的存取时间,同时有更佳的空间利用率。磁盘阵列利用的不同的技术,称为RAID level,不同的level针对不同的系统及应用,以解决数据安全的问题。简单来说,RAID把多个硬盘组合成为一个逻辑扇区,因此,操作系统只会把它当作一个硬盘。 一般高性能的磁盘阵列都是以硬件的形式来达成,进一步的把磁盘存取控制及磁盘阵列结合在一个控制器(RAID controler)或控制卡上,针对不同的用户解决人们对磁盘输输入输出系统的四大要求: (1)增加存取速度, (2)容错(fault tolerance),即安全性 (3)有效的利用磁盘利用率; (4)尽量的平衡CPU,内存及磁盘的性能差异,提高主机的整体工作性能。可提供的功能:

1.冗余(容错)

2.性能提升RAID分类: 1. 硬件RAID:用RAId接口卡来实现;需要内核支持其驱动,并且该类设备设备显示为SCSI设备,代号为/dev/sd*2. 软件RAID:用内核中的MD(multiple devices)模块实现,该类设备在/etc/下表示为:md*;在现在的RH 5版本中使用mdadm工具管理软RAID;(虽然来说可以用软件模拟实现raid,但是相对对磁盘控制的功能及性能不如硬件实现的好,生产环境中最好使用硬件raid几种常见RAID类型描述:

图示:

1. RAID-0 :striping(条带模式),至少需要两块磁盘,做RAID分区的大小最好是相同的(可以充分发挥并优势);而数据分散存储于不同的磁盘上,在读写的时候可以实现并发,所以相对其读写性能最好;但是没有容错功能,任何一个磁盘的损坏将损坏全部数据;

2. RAID-1:mirroring(镜像卷),至少需要两块硬盘,raid大小等于两个raid分区中最小的容量(最好将分区大小分为一样),可增加热备盘提供一定的备份能力;数据有冗余,在存储时同时写入两块硬盘,实现了数据备份;但相对降低了写入性能,但是读取数据时可以并发,几乎类似于raid-0的读取效率;

3. RAID-5 :需要三块或以上硬盘,可以提供热备盘实现故障的恢复;采用奇偶效验,可靠性强,且只有同时损坏两块硬盘时数据才会完全损坏,只损坏一块硬盘时,系统会根据存储的奇偶校验位重建数据,临时提供服务;此时如果有热备盘,系统还会自动在热备盘上重建故障磁盘上的数据;

存储方式:简单来说就是,磁盘阵列的第一个磁盘分段是校验值,第二个磁盘至后一个磁盘再折回第一个磁盘的分段是数据,然后第二个磁盘的分段是校验值,从第三个磁盘再折回第二个磁盘的分段是数据,以此类推,直到放完数据为止。这样数据与校验值的循环分离存储就可以达到一定的故障重建功能;但是raid-5的控制较为复杂,且计算大量的校验码,可能给系统造成额外计算的负担(软raid来说,硬件有自己的数据处理能力)

注:RAID中的容错表示即使磁盘故障,数据仍能保持完整,可让系统存取到正确的数据,而SCSI的磁盘阵列更可在工作中抽换磁盘,并可自动重建故障磁盘的数据。

热备份(hot spare or hot standby driver):为了加强容错的功能以及使系统在磁盘故障的情况下能迅速的重建数据,以维持系统的性能,一般的磁盘阵列系统都可使用热备份(hot spare or hot standby driver)的功能,所谓热备份是在建立(configure) 磁盘阵列系统的时候,将其中一磁盘指定为后备磁盘,该磁盘在平常并不操作,但若阵列中某一磁盘发生故障时,磁盘阵列即以后备磁盘取代故障磁盘,并自动将故障磁盘的数据重建(rebuild)在后备磁盘之上,因为反应快速,加上快取内存减少了磁盘的存取, 所以数据重建很快即可完成,对系统的性能影响很小。

在任何时候都不要用同一个硬盘上的多个区来做RAID,那样不仅不能提高系统的性能,反而会大大降低整体系统的系能;

对上面几种常用的RAID类型分析后,可知,RAID-0主要可以提高磁盘性能,RAID-1主要可以实现备份容错(RAID-5由于控制机制复杂在此暂不使用),所以可以在实际生产环境下考虑结合RAID-0和RAID-1来实现磁盘存储系统的高性能、高容错。

下面图示的两种raid结合方式解析:

对于一:底层分别用有两块硬盘的raid0实现高并发,再集合两个raid0组实现冗余;下层的任意一个raid0组中有任意一块硬盘会使改组失效,但是两外一个组仍能提供全部数据;

对于二:底层用raid-1实现数冗余,上层用raid-2实现高并发,该种结构中任意一个硬盘的故障,不对本组整体数据工作构成破坏性影响;所以感觉该种方案更优异,在实际生产中有部分应用(具体配置过程再文章最后附);

mdadm工具介绍:

描述: mdadm(multiple devices admin)是 linux下标准的的软raid管理工具,是一个模式化工具(在不同的模式下);程序工作在内存用户程序区,为用户提供RAID接口来操作内核的模块,实现各种功能;RedHat已经内置了该工具;官方最新的版本应该是3.2,需要最新版本可以到官方网站下载或 ;mdadm版本为v2.6.9 ;

可能不同的版本选项等略有变动,使用时请注意对照自己版本的man文档;

基本语法:

# mdadm [mode] <raid-device> [options] <component-devices>

目前支持的模式: LINEAR(线性模式)、RAID0(striping条带模式)、RAID1(mirroring)、 RAID-4、RAID-5、 RAID-6、 RAID-、 MULTIPATH和FAULTY

LINEAR:线性模式,该模式不是raid的标准模式,其主要作用是可以实现将几块小的硬盘组合为一块大硬盘来使用;数组存储时一次存满一个硬盘在使用下一个硬盘;对上层来说操作的是一个大硬盘

模式(7种): Assemble:装配模式:加入一个以前定义的阵列;可以使挺值得阵列或从其他主机移出的阵列

Build: 创建:创建一个没有超级块的阵列Create: 创建一个新的阵列,每个设备具有超级块

Follow or Monitor: 监控RAID的状态,一般只对RAID-1/4/5/6/等有冗余功能的模式来使用

Grow:(Grow or shrink) 改变RAID的容量或阵列中的设备数目;收缩一般指的是数据收缩或重建;

Manage: 管理阵列(如添加spare盘和删除故障盘)

Incremental Assembly:添加一个设备到一个适当的阵列。

Misc: 允许单独对阵列中的某个设备进行操作(如抹去superblocks 或停止阵列)

Auto-detect: 此模式不作用于特定的设备或阵列,而是要求在Linux内核启动任何自动检测到的阵列。

OPTIONS:

选择一个模式的选项:(Options for selecting a mode)

-A, --assemble: 加入并开启一个以前定义的阵列

-B, --build: 创建一个没有超级块的阵列(Build a legacy array without superblocks.)

-C, --create: 创建一个新的阵列

-F, --follow, --monitor:选择监控(Monitor)模式-

G, --grow: 改变激活阵列的大小或形态-I,

--incremental: 添加一个单独的设备到合适的阵列,并可能启动阵列

--auto-detect: 请求内核启动任何自动检测到的阵列

不特定于一个模式的选项:(Options that are not mode-specific)

-c, --config=: 指定配置文件,缺省为 /etc/mdadm.conf

-s, --scan: 扫描配置文件或 /proc/mdstat以搜寻丢失的信息。默认配置文件:/etc/mdadm.conf

-h, --help: 帮助信息,用在以上选项后,则显示该选项信息

-v, --verbose: 显示细节,一般只能跟 --detile 或 --examine一起使用,显示中级的信息;

-b, --brief: 较少的细节。用于 --detail 和 --examine 选项

--help-options: 显示更详细的帮助

-V, --version: 版本信息

-q,--quit: 安静模式;加上该选项能使mdadm不显示纯消息性的信息,除非那是一个重要的报告;

create build 或grow时使用的选项:

-n, --raid-devices=: 指定阵列中活动的device数目,不包括spare磁盘,这个数目只能由--grow修改

-x, --spare-devices=:指定初始阵列的冗余device 数目即spare device数目;

-c, --chunk=: Specify chunk size of kibibytes. 缺省为 . chunk-size是一个重要的参数,决定了一次向阵列中每个磁盘写入数据的量

(Chunk :,可以理解为raid分储数据时每个数据段的大小(通常为//等这类数字大小);合理的选择chunk大小非常重要,若chunk过大可能一块磁盘上的带区空间就可以满足大部分的I/O操作,使得数据的读写只局限于一块硬盘上,这便不能充分发挥RAID并发的优势;如果chunk设置过小,任何很小的I/O指令都 可能引发大量的读写操作,不能良好发挥并发性能,占用过多的控制器总线带宽,也影响了阵列的整体性能。所以,在创建带区时,我们应该根据实际应用的需要,合理的选择带区大小。)

-z, --size=:组建RAID1/4/5/6后从每个device获取的空间总数;但是大小必须为chunk的倍数,还需要在每个设备最后给RAID的superblock留至少KB的大小。

--rounding=: Specify rounding factor for linear array (==chunk size)

-l, --level=: 设定 raid level.raid的几倍-

-create: 可用:linear, raid0, 0, stripe, raid1,1, mirror, raid4, 4, raid5, 5, raid6, 6, multipath, mp.

--build: 可用:linear, raid0, 0, stripe

.-p, --layout=:设定raid5 和raid的奇偶校验规则;并且控制故障的故障模式;其中RAID-5的奇偶校验可以在设置为::eft-asymmetric, left-symmetric, right-asymmetric, right-symmetric, la, ra, ls, rs.缺省为left-symmetric

--parity: 类似于--layout=

--assume-clean:目前仅用于 --build 选项

-R, --run: 阵列中的某一部分出现在其他阵列或文件系统中时,mdadm会确认该阵列。此选项将不作确认。

-f, --force: 通常mdadm不允许只用一个device 创建阵列,而且此时创建raid5时会使用一个device作为missing drive。此选项正相反

-N,--name=: 设定阵列的名称

管理模式选项(For Manage mode):

-a, --add: 添加列出的设备到一个工作的阵列中;当阵列处于降级状态(故障状态),你添加一个设备,该设备将作为备用设备并且在该备用设备上开始数据重建。-r, --remove:从阵列中移除列出的设备,并且该设备不能处于活动状态(是冗余盘或故障盘);

-f,--fail:将列出的设备标记为faulty状态,标记后就可以移除设备;(可以作为故障恢复的测试手段)--set-faulty:同上

监控模式选项(For Monitor mode):

-m, --mail: 设置一个mail地址,在报警时给该mail发信;该地址可写入conf文件,在启动阵列是生效

-p, --program, --alert:当检测到一个事件时运行一个指定的程序

-y, --syslog: 设置所有的事件记录于syslog中

-t, --test: 给启动时发现的每个阵列生成test警告信息;该信息传递给mail或报警程序;(以此来测试报警信息是否能正确接收)

MISC模式选项: Usage: mdadm options ... devices ...

-Q, --query: 查看一个device,判断它为一个 md device 或是 一个 md 阵列的一部分

-D, --detail: 打印一个或多个md device 的详细信息

-E, --examine:打印 device 上的 md superblock 的内容创建一个软RAID的基本过程:

(以三个分区模拟创建一个raid5为操作示例,对于level0/1的How-To不再写出,如果理解原理,配置真的很简单;)

1. 生成raid组成: linux中阵列组成单元是分区,分区可以是整个设备也可以是设备多个分区中的一个;在fdisk分区后需要将分区标志改为Linux raid auto类型;

# 分区后如下:

Device Boot Start End Blocks Id System

/dev/sdb1 1 fd Linux raid autodetect

/dev/sdc1 1 fd Linux raid autodetect

/dev/sdd1 1 fd Linux raid autodetect

2. 建立磁盘阵列

# mdadm -C /dev/md0 -a yes -l 5 -n 3 /dev/sd{b,c,d}1

mdadm: array /dev/md0 started.

-C :创建一个阵列,后跟阵列名称

-l :指定阵列的级别;

-n :指定阵列中活动devices的数目

3. 查看阵列状态

[root@bogon ~]# cat /proc/mdstat

Personalities : [raid6] [raid5] [raid4]

md0 : active raid5 sdd1[2] sdc1[1] sdb1[0]

blocks level 5, k chunk, algorithm 2 [3/3] [UUU]

unused devices: <none>

通过cat /proc/mdstat信息查看所有运行的RAID阵列的状态,在第一行中首先是MD的设备名md0,active和inactive选项表示阵列是否能读/写,接着是阵列的RAID级别raid5,后面是属于阵列的块设备,方括号[]里的数字表示设备在阵列中的序号,(S)表示其是热备盘,(F)表示这个磁盘是 faulty状态。下一行中首先是阵列的大小,用块数来表示;后面有chunk-size的大小,然后是layout类型,不同RAID级别的 layout类型不同,[3/3] [UUU]表示阵列有3个磁盘并且3个磁盘都是正常运行的,而[2/3]和[_UU] 表示阵列有3个磁盘中2个是正常运行的,下划线对应的那个位置的磁盘是faulty状态的。

查看阵列的详细信息:

[root@bogon ~]# mdadm --detail /dev/md0

/dev/md0:

Version : 0.

Creation Time : Tue Mar ::

Raid Level : raid5

Array Size : (9. GiB . GB)

Used Dev Size : (4. GiB 5. GB)

Raid Devices : 3

Total Devices : 3

Preferred Minor : 0

Persistence : Superblock is persistent

Update Time : Tue Mar ::

State : clean

Active Devices : 3

Working Devices : 3

Failed Devices : 0

Spare Devices : 0

Layout : left-symmetric 校验规则

Chunk Size : K

UUID : e0dd1:d7aacd:5ffcdf9b:c1aafd

Events : 0.2

Number Major Minor RaidDevice State

0 8 0 active sync /dev/sdb1

1 8 1 active sync /dev/sdc1

2 8 2 active sync /dev/sdd1

4. mdadm.conf配置:mdadm.conf是该软件的默认配置文件,主要作用是方便跟踪软RAID的配置,尤其是可以配置监视和事件上报选项。其中写入每一个阵列组成的详细情况,用于在下次开启阵列后依据此文件重新装配(assemble)开启阵列,否则就需要在开启时手动定义阵列中的成员;当然是推荐创建该文件,防止出现意外情况,具体的详细配置及示例可以参看man文档# man mdadm.conf

[root@bogon ~]# echo "DEVICE /dev/sdb1 /dev/sdc1 /dev/sdd1 " >> /etc/mdadm.conf

[root@bogon ~]# mdadm -Ds >> /etc/mdadm.conf

[root@bogon ~]# echo "MAILADDR mospiral@gmail.com" >> /etc/mdadm.conf

MAILADDR指定出问题时监控系统发邮件的地址

# 格式如下:

DEVICE /dev/sdb1 /dev/sdc1 /dev/sdd1

Linux阵列 RAID详解(linux做raid10)

ARRAY /dev/md0 level=raid5 num-devices=3 metadata=0. UUID=e0dd1:d7aacd:5ffcdf9b:c1aafd

MAILADDR mospiral@gmail.com

#DEVICE行指明:依据该配置文件开启阵列时,去查找那些设备的超级快信息;若没有该行,

就去搜索mtab中所有设备分区的超级快信息;所以改行可以不写,但是只要写上,以后添加spare

设备时就需要同时修改改行信息;

#ARRAY 行指明raid的名称,级别uuid等基本信息

#可以添加诸如MAILADDR及PROGRAM等指定monitor状态下的监控报警信息;

磁盘阵列的管理: 可以在manage模式下对磁盘进行各种管理工作;

给raid-5新增一个spare盘:

[root@bogon ~]# mdadm -a /dev/md0 /dev/sda5

mdadm: added /dev/sda5

此时查看状态:

[root@bogon ~]# cat /proc/mdstat

Personalities : [raid6] [raid5] [raid4]

md0 : active raid5 sda5[3](S) sdd1[2] sdc1[1] sdb1[0]

blocks level 5, k chunk, algorithm 2 [3/3] [UUU]

unused devices: <none>

模拟硬盘故障:

[root@bogon ~]# mdadm -f /dev/md0 /dev/sdd1

mdadm: set /dev/sdd1 faulty in /dev/md0

# 此时查看状态,发现概念刚才的热备盘已经顶替了故障盘的位置,

# 并且进度条显示数据重建过程:

[root@bogon ~]# cat /proc/mdstat

Personalities : [raid6] [raid5] [raid4]

md0 : active raid5 sda5[3] sdd1[4](F) sdc1[1] sdb1[0]

blocks level 5, k chunk, algorithm 2 [3/2] [UU_]

[>....................] recovery = 1.3% (/) finish=6.0min speed=K/sec

unused devices: <none>

热移除故障的硬盘:

[root@bogon ~]# mdadm -r /dev/md0 /dev/sdd1

mdadm: hot removed /dev/sdd1

[root@bogon ~]# cat /proc/mdstat

Personalities : [raid6] [raid5] [raid4]

md0 : active raid5 sda5[3] sdc1[1] sdb1[0]

blocks level 5, k chunk, algorithm 2 [3/2] [UU_]

[===>.................] recovery = .1% (/) finish=4.6min speed=K/sec

unused devices: <none>

对于有冗余的raid形式,在单一磁盘故障时一般能在一段时间内重建数据;但是数据量非常大时,重建会非常缓慢,且重建过程系统压力比较大,此时需要多关注系统负载,防止重建过程出现错误;在热移除故障盘一户,也需要尽快的换上新硬盘,并且添加spare盘;在故障修复,重建重建之后,需要重新生成配置文件,防止在下次开启时,按照最初的定义模式开启;

停止RAID:

# 指定停止某个阵列

[root@bogon ~]# mdadm -S /dev/md0

# 停止配置文件中定义的所有阵列

[root@bogon ~]# mdadm -Ss

mdadm: stopped /dev/md0

# -s –scan去查询配置文件或没有配置文件时查询mdstat中的所有阵列

开启RAID:

[root@bogon ~]# mdadm -As

mdadm: /dev/md0 has been started with 2 drives (out of 3).

# -s –scan:根据配置文件开启所有的阵列,此时由于故障恢复过,

# 但是由于未重建配置文件,阵列我不能加载上新添加的硬盘;(需要停掉,重新手动指定)

[root@bogon ~]# cat /proc/mdstat

Personalities : [raid6] [raid5] [raid4]

md0 : active raid5 sdb1[0] sdc1[1]

blocks level 5, k chunk, algorithm 2 [3/2] [UU_]

unused devices: <none>

若此时没有配置文件,就需要手动指定设备名称:

[root@bogon ~]# mdadm -A /dev/md0 /dev/sdb1 /dev/sdc1 /dev/sda5

mdadm: /dev/md0 has been started with 3 drives.

# 注:将一个raid设备添加入md阵列后,md的信息会写入到该设备分区的superblock中;

# 在手动装配时;mdadm工具会自动验证阵列配置是否合法,并且做出相应的动作;

若新接手一个raid,没有配置文件,或忘记设备的准确组成,就需要按分区逐个检查是否是raid设备及其他信息,然后根据信息装配阵列:

[root@bogon ~]# mdadm -E /dev/sdb1

/dev/sdb1:

Magic : ab4efc

Version : 0..

UUID : e0dd1:d7aacd:5ffcdf9b:c1aafd

Creation Time : Tue Mar ::

Raid Level : raid5

Used Dev Size : (4. GiB 5. GB)

Array Size : (9. GiB . GB)

Raid Devices : 3

Total Devices : 3

Preferred Minor : 0

Update Time : Tue Mar ::

State : clean

Active Devices : 3

Working Devices : 3

Failed Devices : 0

Spare Devices : 0

Checksum : b0cdf - correct

Events : 8

Layout : left-symmetric

Chunk Size : K

Number Major Minor RaidDevice State

this 0 8 0 active sync /dev/sdb1

0 0 8 0 active sync /dev/sdb1

1 1 8 1 active sync /dev/sdc1

2 2 8 5 2 active sync /dev/sda5

# 该处显示出的是该分区superblock中包含的md信息;没有配置文件时,可以依据该信息装配md;

删除阵列:

若需要彻底清除这个阵列:

[root@bogon ~]# umount /dev/md0

mdadm -Ss /dev/md0

[root@bogon ~]# mdadm --zero-superblock /dev/sd{b,c,d}1

# --zero-superblock 加上该选项时,会判断如果该阵列是否包

# 含一个有效的阵列超级快,若有则将该超级块中阵列信息抹除。

[root@bogon ~]# rm /etc/mdadm.conf

RAID优化:

(1) 设置stride值

The stride is the software RAID device's chunk-size in filesystem blocks.For example,with an ext3 filesystem that will have an 4KB block size on a RAID device with a chunk-size of KB, the stride should be set to :(翻译的很纠结,就贴上教材原文了。)

mk2fs -j -b -E stride= /dev/md0

# 设置时,需要用-E选项进行扩展

设定良好的stride值,可以在后期使用时,减少写入数据时对数据块计算的负担,从而提高RAID性能;

附:RAID 1-0双层架构的方法:

首先创建两个底层RAID-1

[root@bogon ~]# mdadm -C /dev/md0 -a yes -l 1 -n 2 /dev/sd[bc]1

mdadm: array /dev/md0 started.

[root@bogon ~]# mdadm -C /dev/md1 -a yes -l 1 -n 2 /dev/sd[bc]2

mdadm: array /dev/md1 started.

用两个RAID-1实现上层RAID-0:

[root@bogon ~]# mdadm -C /dev/md2 -a yes -l 0 -n 2 /dev/md[]

mdadm: array /dev/md2 started.

查看阵列状态:

[root@bogon ~]# cat /proc/mdstat

Personalities : [raid6] [raid5] [raid4] [raid0] [raid1]

md2 : active raid0 md0[0] md1[1]

blocks k chunks

md1 : active raid1 sdb2[0] sdc2[1]

blocks [2/2] [UU]

md0 : active raid1 sdb1[0] sdc1[1]

blocks [2/2] [UU]

unused devices: <none>

创建配置文件:

[root@bogon ~]# mdadm -Ds > /etc/mdadm.conf

停止与开启阵列:

[root@bogon ~]# mdadm -Ss

mdadm: stopped /dev/md2

mdadm: stopped /dev/md1

mdadm: stopped /dev/md0

[root@bogon ~]# mdadm -As

mdadm: /dev/md0 has been started with 2 drives.

mdadm: /dev/md1 has been started with 2 drives.

mdadm: /dev/md2 has been started with 2 drives.

##上述关闭与开启过程,系统能只能识别层级,关闭先关闭上层,

##后开启上层;防止了冲突;

linux根文件系统的挂载过程详解 st1:*{behavior:url(#ieooui)}一:前言前段时间在编译kernel的时候发现rootfs挂载不上。相同的root选项设置旧版的image却可以。为了彻底解决这个问题。研究了一

Linux 系统内核的调试详解 调试是软件开发过程中一个必不可少的环节,在Linux内核开发的过程中也不可避免地会面对如何调试内核的问题。但是,Linux系统的开发者出于保证内核

进程的内核栈是什么?浅谈Linux的进程内核栈 在重游《LDD3》的时候,又发现了一个当年被我忽略的一句话:内核具有非常小的栈,它可能只和一个字节大小的页那样小针对这句话,我简单地学习

标签: linux做raid10

本文链接地址:https://www.jiuchutong.com/biancheng/361975.html 转载请保留说明!

上一篇:Linux禁用root账户的方法(linux禁止root用户远程登录)

下一篇:linux根文件系统的挂载过程详解(linux根文件系统直接解压到硬盘)

  • 什么叫直接税?直接税有哪些?
  • 财务刷卡手续费怎么处理
  • 同一控制下资产收购
  • 固定资产遭受自然灾害账务处理
  • 内部损益表
  • 以前年度漏记一笔短期借款但本金利息支出记账了
  • 企业自建房转让如何交土地增值税
  • 季度企业所得税申报表怎么填写
  • 分公司负债,总公司要负担
  • 企业银行保证金账户怎么查询
  • 商会会费收取
  • 旧机器设备出口
  • 个人取得经济补偿金个人所得税计算
  • 发生坏账损失账务处理
  • 融资租入固定资产改建支出计入
  • 企业所得税汇算表
  • qctray.exe - qctray进程 是什么文件 作用是什么
  • 发票产生的材料是什么
  • 季度资产总额怎么填写
  • 应收账款怎么做分录
  • 利得和损失计入哪里
  • 在linux操作系统中
  • 认定科技型中小企业简单吗
  • win7有线连接怎么设置
  • 现金流量套期的例子
  • 现金付款凭证是什么意思
  • 顺流交易合并抵消 chenyiwei
  • 后端返回pdf文件地址,前端怎么渲染到页面
  • php设计模式六大原则
  • 多提附加税跨年怎么计算
  • 所得税时间性差异与永久性有关吗
  • 应付现金股利通过
  • 个人独资企业是小规模纳税人吗
  • 让税务局代开的发票直接交纳的税金怎么做会计分录?
  • 本月职工工资
  • php超时限制
  • 生产企业计提车折旧年限
  • thinkphp框架结构
  • 小规模纳税人开专票需要交税吗
  • 自然语言处理属于人工智能的哪个领域
  • opencv教程
  • json有几种基本结构
  • tsop封装
  • 增值税免税申报
  • 看望生病职工慰问品
  • 用python创建一个列表
  • php cms
  • MySQL常用命令关键字
  • pythonproperty
  • 会务费什么企业可以开
  • 小微小型微利企业表述正确的有
  • 出口企业申报退税不再提供纸质
  • 设计协会会长
  • 年末未缴增值税应符合计算逻辑
  • 资金退回怎么记账
  • 核销贷款收回账务怎么做
  • 收到公众号消息提醒
  • 应收账款平账怎么处理
  • 资产处置损益计入利润表哪个项目
  • 增值税发票红冲和作废的区别
  • 施工企业主营业务收入二级科目有哪些
  • sql server2019还原数据库
  • 查找星期几
  • 电脑爆音卡死
  • vpngui.exe是什么进程
  • 打开安全启动
  • win10更新到win11
  • linux的含义
  • win7 注册表 ahci
  • 在Linux系统中如果想移出已安装的软件
  • cocos做游戏
  • docker如何部署环境到生产
  • js的scrolltop
  • jquery 插件写法
  • javascriptjs
  • 个人所得税预扣预缴办法
  • 增值税进项发票如何做账
  • 增值税电子普通发票需要盖章吗
  • 武汉市房产证契税 2023
  • 国税申报时间2023
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设