导航:首页 > 操作系统 > linux下库文件

linux下库文件

发布时间:2023-02-16 15:51:25

linux 里有/lib和/usr/lib,这两个目录下的库文件有什么区别吗

/lib这个目录下的函数库是在开机时会用到的函数库,还有/bin、/sbin里面的那些命令调用的函数库,/lib/moles下面还会放置内核模块(驱动程序);而/usr/lib目录放置的是应用软件用到的函数库文件。

❷ Linux 里有/lib和/usr/lib,这两个目录下的库文件有什么区别吗如果没区别为什么又要分开放呢

/lib/ — 包含许多被 /bin/ 和 /sbin/ 中的程序使用的库文件。目录 /usr/lib/ 中含有更多用于用户程序的库文件。 /lib目录下放置的是/bin和/lib目录下的文件的名称遵循下面的格式: libc.so.* ld* 仅仅被/usr目录下的程序所使用的共享库不必放到/sbin所需要的,也可以放到/usr/lib下。 /bin/ — 用来贮存用户命令。目录 /usr/bin 也被用来贮存用户命令。 /sbin/ — 许多系统命令(例如 shutdown)的贮存位置。目录 /usr/sbin 中也包括了许多系统命令。 /root/ — 根用户(超级用户)的主目录。 /mnt/ — 该目录中通常包括系统引导后被挂载的文件系统的挂载点。譬如,默认的光盘挂载点是 /mnt/cdrom/. 另外/lib 可以说是内核级的。。 /usr/lib 系统级的。。 /usr/local/lib 用户级的。。/boot/ — 包括内核和其它系统启动期间使用的文件。 /lost+found/ — 被 fsck 用来放置零散文件(没有名称的文件)。 /lib/ — 包含许多被 /bin/ 和 /sbin/ 中的程序使用的库文件。目录 /usr/lib/ 中含有更多用于用户程序的库文件。 /dev/ — 贮存设备文件。 /etc/ — 包含许多配置文件和目录。 /var/ — 用于贮存variable(或不断改变的)文件,/usr/ — 包括与系统用户直接有关的文件和目录,/proc/ — 一个虚拟的文件系统(不是实际贮存在磁盘上的),/initrd/ — 用来在计算机启动时挂载 initrd.img 映像文件的目录以及载入所需设备模块的目录。 这就是你想得到的答案。《Linux就该这么学》里有相关介绍,建议看看。

❸ Linux里面哪一个目录包含已安装的软件程序和库

Linux目录包含已经安装的软件,程序和库是在一个程序里面,它的一个总目录里面是含有的。

❹ linux mysql数据库文件在哪

FreeBSD主机上的mysql安装的时候数据库文件放在/var/db/mysql下,在Linux主机上的默认存储位置是/var/lib/mysql/下。如果想更换mysql的数据文件的存储位置,则:FreeBSD下:#
/usr/local/etc/rc.d/mysql-server
stop(停止mysql)#
mkdir
/other..

❺ Linux下的静态库和动态库

静态库

可以把它想象成是一些代码的集合,在可执行程序运行前就已经加到了代码中,成为了执行程序的一部分,一般是以.a为后缀的文件名,Windows下后缀为.lib。静态库的命名也分为三部分,1、前缀:lib,2、库的名称:随意,如lisi,3、后缀:.a。

静态库优缺点

上面简单介绍了静态库,那它自然也会有优缺点,这里来介绍下它的优缺点。

优点:1、在最后,函数库是被打包到应用程序中的,实现函数本地化、寻址方便、高效。2、程序在运行的时候,与函数库没有关系,移植性更强。

缺点:1、消耗资源较大,每个进程在使用静态库的时候,都要复制一份才可以,这也就造成了内存的消耗。2、在程序更新、部署、发布的时候,使用静态库相对麻烦,如果一个静态库更新了,那它的应用程序都需要重新编译,再发送给用户,有的时候可能只是一个小的改动,但对于用户来说,会导致整个程序重新下载。

动态库

在程序编译时不会被连接到目标代码中,在后期运行时才会载入,不同的应用程序如果调用相同的库,内存中只有一份共享库的拷贝,也就避免了空间的浪费问题。一般以.so作为文件后缀名,也分为三部分:1、前缀:lib,2、库名称:自定义,3、后缀:.so

动态库优缺点

优点:1、节省内存2、部署、升级相对方便,只需要更换动态库,再重新启动服务即可。

缺点:1、加载速度比静态库慢2、移植性较差,需要把所有用到的动态库进行移植。

❻ linux下的oracle库文件能否导入windows2000中

分类: 电脑/网络 >> 操作系统/系统故障
解析:

当然可以,使用oracle自己的导入exp导出工具imp就可以做。作为一个oracle的管理员,exp和imp也是最常用的备份手段之一。

另附oracle的导入导出文档一个。

oracle Export and Import 简介

1、Export/Import的用处

Oracle Export/Import工具用于在数据库之间传递数据。

Export从数据库中导出数据到mp文件中

Import从mp文件中到入数据导数据库中

下面是一般使用他们的情况

(1)、两个数据库之间传送数据

同一个版本的oracle Server之间

不同版本的oracle Server之间

同种OS之间

不同种OS之间

(2)、用于数据库的备份和恢复

(3)、从一个SCHEMA传送到另一个SCHEMA

(4)、从一个TABLESPACE传送到另一个TABLESPACE

2、DUMP文件

EXPORT到出的是二进制格式的文件,不可以手工编辑,否则会损坏数据。

该文件在ORACLE支持的任何平台上都是一样的格式,可以在各平台上通用。

DUMP文件在IMPORT时采用向上兼容方式,就是说ORALCE7的DUMP文件可以导入到ORACLE8中,但是版本相差很大的版本之间可能有问题。

3、EXPORT/IMPORT过程

EXPORT导出的DUMP文件包含两种基本类型的数据

- DDL

- Data

DUMP文件包含所有重新创建Data Dictionary的DDL语句,基本上是可以读的格式。

但是应该注意的是,千万不要用文本编辑器编辑之,oracle说不支持这样做的。

下面列出的是DUMP文件中包括的ORACLE对象,分为TABLE/USER/FULL方式,有些对象

只是在FULL方式下才有(比如public synonyms, users, roles, rollback segments等)

Table mode User Mode Full Database Mode

---------------------- ---------------------- -------------------------

Table definitions Table definitions Table definitions

Table data Table data Table data

Owner's table grants Owner's grants Grants

Owner's table indexes Owner's indexes Indexes

Table constraints Table constraints Table constraints

Table triggers Table triggers All triggers

Clusters Clusters

Database links Database links

Job queues Job queues

Refresh groups Refresh groups

Sequences Sequences

Snapshots Snapshots

Snapshot logs Snapshot logs

Stored proceres Stored proceres

Private synonyms All synonyms

Views Views

Profiles

Replication catalog

Resource cost

Roles

Rollback segments

System audit options

System privileges

Tablespace definitions

Tablespace quotas

User definitions

4、IMPORT时的对象倒入顺序

在倒入数据时,ORACLE有一个特定的顺序,可能随数据库版本不同而有所变化,

但是

现在是这样的。

1. Tablespaces 14. Snapshot Logs

2. Profiles 15. Job Queues

3. Users 16. Refresh Groups

4. Roles 17. Cluster Definitions

5. System Privilege Grants 18. Tables (also grants,ments, indexes, constraints, auditing)

6. Role Grants

7. Default Roles 19. Referential Integrity

8. Tablespace Quotas 20. POSTTABLES actions

9. Resource Costs 21. Synonyms

10. Rollback Segments 22. Views

11. Database Links 23. Stored Proceres

12. Sequences 24. Triggers, Defaults and Auditing

13. Snapshots

按这个顺序主要是解决对象之间依赖关系可能产生的问题。TRIGGER最后导入,所以在INSERT数据到数据库时不会激发TRIGGER。在导入后可能会有一些状态是INVALID的PROCEDURE,主要是IMPORT时会影响一些数据库对象,而IMPORT并不重新编译PROCEDURE,从而造成这种情况,可以重新编译之,就能解决这个问题。

5、兼容性问题

IMPORT工具可以处理EXPORT 5.1.22之后的版本导出的DUMP文件,所以你用ORACLE7的IMPORT处理ORACLE6的DUMP文件,依次类推,但是ORACLE如果版本相差很大有可能不能处理。具体的问题可以参照相应的文档,比如有关参数设置等(COMPATIBLE参数)

6、EXPORT需要的VIEW

EXPORT需要的VIEW是由CATEXP.SQL创建,这些内部VIEW用于EXPORT组织DUMP文件中数据格式。

大部分VIEW用于收集创建DDL语句的,其他的主要供ORACLE开发人员用。

这些VIEW在不同ORACLE版本之间有可能不同,每个版本可能都有新的特性加入。

所以在新的版本里面执行旧的mp文件会有错误,一般可以执行CATEXP.SQL解决这些问题,

解决向后兼容问题的一般步骤如下:

导出数据库的版本比目标数据库老的情况:

- 在需要导入的目标数据库中执行旧的CATEXP.SQL

- 使用旧的EXPORT导出DUMP文件

- 使用旧的IMPORT导入到数据库中

- 在数据库中执行新的CATEXP.SQL,以恢复该版本的EXPORT VIEW

导出数据库的版本比目标数据库新的情况:

- 在需要导入的目标数据库中执行新的CATEXP.SQL

- 使用新的EXPORT导出DUMP文件

- 使用新的IMPORT导入到数据库中

- 在数据库中执行旧的CATEXP.SQL,以恢复该版本的EXPORT VIEW

7、碎片整理

EXPORT/IMPORT一个很重要的应用方面就是整理碎片。因为如果时初次IMPPORT,就会重新CREATE TABLE 再导入数据,所以整张表都是连续存放的。另外缺省情况下EXPORT会在生成DUMP文件是“压缩(COMPRESS)”TABLE,但是这种压缩在很多情况下被误解。事实上,COMPRESS是改变STORAGE参数INITIAL的值。比如:

CREATE TABLE .... STORAGE( INITIAL 10K NEXT 10K..)

现在数据已经扩展到100个EXTENT,如果采用COMPRESS=Y来EXPORT数据,则产生的语句时 STORAGE( INITIAL 1000K NEXT 10K)

我们可以看到NEXT值并没有改变,而INITIAL是所有EXTENT的总和。所以会出现如下情况,表A有4个100M的EXTENT,执行DELETE FROM A,然后再用COMPRESS=Y 导出数据,产生的CREATE TABLE语句将有400M的INITIAL EXTENT。即使这是TABLE中已经没有数据!!这是的DUMP文件即使很小,但是在IMPORT时就会产生一个巨大的TABLE.

另外,也可能会超过DATAFILE的大小。比如,有4个50M的数据文件,其中表A有15个10M的EXTENT,如果采用COMPRESS=Y的方式导出数据,将会有INITIAL=150M,那么在重新导入时,不能分配一个150M的EXTENT,因为单个EXTENT不能跨多个文件。

8、在USER和TABLESPACE之间传送数据

一般情况下EXPORT的数据要恢复到它原来的地方去。如果SCOTT用户的表以TABLE或USER方式EXPORT数据,在IMPORT时,如果SCOTT用户不存在,则会报错!

以FULL方式导出的数据带有CREATE USER的信息,所以会自己创建USER来存放数据。

当然可以在IMPORT时使用FROMUSER和TOUSER参数来确定要导入的USER,但是要保证TOUSER一定已经存在啦。

9、EXPORT/IMPORT对SQUENCE的影响

在两种情况下,EXPORT/IMPORT会对SEQUENCE。

(1)如果在EXPORT时,用户正在取SEQUENCE的值,可能造成SEQUENCE的不一致。

(2)另外如果SEQUENCE使用CACHE,在EXPORT时,那些在CACHE中的值就会被忽略的,只是从数据字典里面取当前值EXPORT。

如果在进行FULL方式的EXPORT/IMPORT时,恰好在用sequence更新表中某列数据,而且不是上面两种情况,则导出的是更新前的数据。

如果采用常规路径方式,每一行数据都是用INSERT语句,一致性检查和INSERT TRIGGER

如果采用DIRECT方式,某些约束和trigger可能不触发,如果在trigger中使用sequence.nextval,将会对sequence有影响。

❼ linux环境下编译so库和编译可执行文件

gcc -fPIC -shared caculate.c -o libcaculate.so
-fPIC 压制警告
-shared 动态库
-o 生成目标的文件名

caculate.c

gcc -rdynamic -o main main.c
-rdynamic 生成可执行文件
-o 目标文件名

main是linux环境下的一个可执行文件。

main.c

gcc -c main.c -o main.o
gcc -c minus.c -o minus.o
gcc -c mulit.c -o mulit.o
gcc -c plus.c -o plus.o

gcc main.o minus.o mulit.o plus.o -o myapp

❽ Linux是怎么包含指定的库文件

linux下C语言编程,指定包含目录和引用库文件的gcc参数:

指定包含目录:-I path

指定库文件目录:-L path

path为相应的目录路径,如:

gcc-I$HOME/includetest.c-otest-L$HOME/lib-lmylib

❾ linux下sqlite如何制作成动态库库

1、下载源码解压缩sqlite-autoconf-3300100.tar.gz

2、进入解压目录,执行:

#:./configure --host=arm CC=arm-linux-gnueabi-gcc CXX=arm-linux-gnueabi-g++ --prefix=/usr

其中--host=要运行程序的主机

CC/CXX为用到的交叉编译工具链
--prefix=安装目录

3、make

将在当前文件目录下,自动生成可执行文件sqlite3及静态库文件sqlite3.a文件;
4、sudo make install

此命令会将可执行文件及静态库文件拷贝至安装目录中(也可手动拷贝)

5、以上步骤生成的可执行文件包含大量调试信息,文件比较大,可使用strip命令去掉其中的调试信息;

#:arm-linux-gnueabi-strip sqlite3

6、生成动态库文件:

arm-linux-gnueabi-gcc sqlite3.c -lpthread -ldl -fPIC -shared -o libsqlite3.so

交叉编译sqlite3,生成动态库

标签:ref gcc host pthread strip config 安装 目录 工具链

❿ Linux系统的库文件一般放在( )目录下

Linux的系统文件放在/bin、/sbin和/usr目录下。/bin是比较重要的系统二进制文件,都可以在单用户模式下执行,cat和ls命令都在这里。
/usr命令包含所有系统类的命令和函数库,/sbin命令包含的是只能用root用户才能执行的命令。这三个目录都是只有root用户才有写入权限。更多命令介绍可查看“Linux命令大全”。

阅读全文

与linux下库文件相关的资料

热点内容
有pdf却打不开 浏览:460
七星彩软件app怎么下载 浏览:217
32单片机的重映射哪里改 浏览:816
为什么前端不用刷算法题 浏览:708
对称加密系统和公钥加密系统 浏览:428
历史地理pdf 浏览:606
物联网云服务器框架 浏览:648
sybaseisql命令 浏览:183
android权威编程指南pdf 浏览:663
哪些软件属于加密软件 浏览:646
文件夹75丝什么意思 浏览:470
最便宜sop8单片机 浏览:966
图解周易预测学pdf 浏览:420
c盘莫名奇妙多了几个文件夹 浏览:171
贵州花溪门票优惠app哪个好 浏览:803
如何说话不会让人有被命令的感觉 浏览:440
哪里可下载湘工惠app 浏览:265
福特python 浏览:312
pdf转换成word表格 浏览:353
无线远端服务器无响应是什么意思 浏览:672