oracle 11g断网安装时,没有检测net的功能,所以安装完后,netstat -an 发现自动监听的是127.0.0.1:1521,这样安装完成后,其他的主机根本无法连接,是什么原因呢?...localhost # ::1 localhost ....此处添加 主机IP 主机名 在最后一行加入 本机IP 主机名 保存即可 使用lsnrctl stat查看监听状态...此时监听的还是 127.0.0.1:1521这个IP 修改监听文件 listener.ora 文件在 D:\app\Administrator\product\11.2.0\dbhome_1\network...(SERVER = DEDICATED) (SERVICE_NAME = orcl) ) ) 同样把localhost换成自己的主机名 再用lsnrctl.ora检测,发现监听...IP地址变为:192.168.1.251:1521 0.0.0.0 (192.168.1.251为本主机IP) 成功!
默认的wireshark是不能监听到127.0.0.1的网络通信的 , 需要安装一个软件就可以了 先安装这个npcap , 他会卸载本地原来的wincap等 , 不需要管. https://nmap.org
直接IO,绕过缓存,不会出现write成功数据丢失情况。...注意:直接IO的缺点就是如果访问的数据不在应用程序缓存中,那么每次数据都会直接从磁盘进行加载,这种直接加载会非常慢,通常直接IO跟异步IO结合使用会得到较好的性能。...\n"; char* buf = NULL; //buf = (char*)malloc(BUF_LEN); //地址要是512的倍数——内存边界对齐 posix_memalign((void...---- O_SYNC 缓存同步 为了保证磁盘系统与缓冲区内容一致,Linux系统提供了sync,fsync,fdatasync三个函数。...---- Linux文件IO流程图 内核中会有一个线程,不断地将高速页缓冲区中的数据写入到物理磁盘中。
今天我们要学习的是基础IO部分,主要涉及内存和外设之间的数据交互。接下来,就让我们共同探讨这部分内容吧,那我们就开始吧!...本文章重点: 复习C文件IO相关操作 认识文件相关系统调用接口 认识文件描述符,理解重定向 对比fd和FILE,理解系统调用和库函数的关系 理解文件系统中inode的概念 认识软硬链接,对比区别 认识动态静态库...buf:需要写入文件的字符串的起始地址。 count,写入文件的字符串的长度。 其中第三个参数需要注意,传入的字符串长度是不算 \0 的,因为这是系统调用接口,并非C语言。...3.read函数 read函数是Linux下的一个系统调用接口,C语言的fread函数的底层就是read。作用为从一个特定的文件流中读取内容。...4.close函数 close函数也是Linux下的一个系统调用接口,C语言的fclose底层就是close。 参数 fd:就是调用open时的返回值,本质是第一个文件描述符。
但是最让人烦的问题是这些语言之间的 IO 接口都是不一样的,这样子导致我们学习成本很高! 这些语言拥有文件操作接口的目的找到文件,然后对文件进行操作。那么文件是在磁盘上,磁盘是属于硬件。...所以我们只要搞清楚了操作系统提供的 IO 接口,那么其它语言只是对其的一个包装而已!下面我们一起来认识一下系统的IO接口! Ⅱ....系统IO接口 一、open接口 #include #include #include int open(const char *
本文将结合用户态的接口以及内核态的实现剖析文件IO。...Reference: The Linux Programming Interface: Chapter 4/14/15, Kernel/fs 通用接口 通用IO包含open/read/write/close...文件创建标志 - 创建以及后续IO的选项,不可读写。...因为这个原因,写操作并不能实时的进行持久化,需要linux使用journal机制来保证文件系统的崩溃一致性,然而journal机制本身又需要进行flush。...---- Ioctl 非通用的IO操作,通过指定的request值表示操作,后续传递参数的类型通过request的值进行解释。
仿真器ganache-cli是开发以太坊智能合约和去中心化应用(DApp)必不可少的工具软件,本文将介绍启动ganache-cli时如何自定义设置其监听端口和监听地址。...例如,下面的命令将启动ganache-cli在7878端口监听: ~$ ganache-cli -p 7878 指定监听地址 默认情况下,ganache-cli的监听地址为0.0.0.0,这意味着从仿真器所在网络上的任意计算机都可以访问这个节点...例如,下面的命令将启动ganache-cli在地址127.0.0.1监听,这样只有本机上的应用才可以访问仿真节点: ~$ ganache-cli -h 127.0.0.1 同时指定监听地址和监听端口 同时使用...-h和-p启动选项来设定监听地址和端口。...例如,下面的命令将启动ganache-cli在地址127.0.0.1的7878端口监听: ~$ ganache-cli -h 127.0.0.1 -p 7878 如果你希望马上开始学习以太坊DApp开发
在Linux地址下,这种地址叫做 虚拟地址 我们在用C/C++语言所看到的地址,全部都是虚拟地址!物理地址,用户一概看不到,由OS统一管理 OS必须负责将 虚拟地址 转化成 物理地址 。...程序内部使用的地址都是基于虚拟地址空间,页表负责将这些地址实时映射到实际的物理内存地址,为程序的正确执行提供支撑 03.Linux2.6内核进程调度队列 前面提到的nice值范围在[-20,19]...在 Linux 2.6 内核中,进程调度得到了很大的改进,以提高系统的效率、响应性和可扩展性。...Linux 2.6 使用了一种称为 Ø(1)调度器 的调度算法,这种算法通过使用多个调度队列来达到高效调度。...普通进程优先级(100-139)是根据进程的行为(如是否等待IO操作、交互操作频繁等)动态调整的。系统会奖励交互式任务较高的优先级,而使得计算密集型任务可能降低优先级。
2、将两个文件的结果都写到一个文件 这个意思是1号文件的地址变成了all.log 然后2也被写入到原来1的位置,所以最后其实都被写到了all.log文件里面 三、如何理解一切皆文件 1、计算机上进行的所有操作...——>其实我们还可以发现 这个文件其实就是基类,而外设就是派生类,然后指针指向什么就调用什么对象,这就是多态,只不过Linux必须用C语言写,所以只能用函数指针来完成这个工作!!...4、理解了Linux的一切皆文件后,懂得了文件操作的底层,即使以后在使用其他语言的文件操作时对接口不熟,但只要给时间查一下,很快就会懂得怎么用了!!...——>因为很多地方需要对软件做分层,设置出各种虚拟化的场景(比如刚刚提到的文件虚拟系统就是,只不过Linux必须用C写,否则肯定用C++写更方便) ——>封装、继承、多态!...缓冲区的大小 #define FLUSH_NOW 1 //立刻刷新 #define FLUSH_LINE 2 //行刷新 #define FLUSH_ALL 4 //全刷新 typedef struct IO_FILE
这个地址绝对不是物理地址,理论上修改了数据为300之后不可能在输出有100,访问一个地址怎么可能又是100也是300。这个地址在系统层面上称之为虚拟地址。...在32位和64位下的地址空间大小是不一样的,为了方便这里使用32位来表述。32位从低到高一个有4GB的地址空间范围,实际上这个地址空间当中打印出来的地址,是该空间内对应的地址。...其实PCB和地址空间都是在物理内存里面的,只不过要访问初始化全局数据的时候,不在地址空间上保存,地址空间只会提供线性连续地址,让用户之后通过虚拟地址的地址空间,将虚拟地址转化到为了物理内存中。...,所以在地址空间的初始化数据中就有它的地址虚拟地址,页表的左侧也有它的虚拟地址,在页表右侧就有它对应的物理地址。...所以虚拟地址相同而物理地址不同。 3. 进程调度 Linux中的nice值并不是能任意调度的,而是从-20到19,这40个数字之间变换。
Linux 中主要有五种IO模式:阻塞IO, 非阻塞IO, IO 多路复用,信号驱动IO和异步IO; 如果从同步非同步,阻塞非阻塞角度来看,又可以分为:同步阻塞IO, 同步非阻塞IO,异步阻塞IO和异步非阻塞...IO; 每种IO模型,都有自己的使用模式,他们对于特定的应用程序都有自己的优点:其简单分布如下图所示 ?...每种IO模型都有自己的使用场景,他们对于特定的应用程序都有自己的优点; 具体可参考:https://blog.csdn.net/tjiyu/article/details/52959418 XXX TO-DO
fdset 从用户态拷贝到内核态,在高并发下是个巨大的性能开销(可优化为不拷贝); 调用 select 阻塞后,用户进程虽然没有轮询,但在内核还是通过遍历的方式来检查 fd 的就绪状态(可通过异步 IO...在 Linux 2.4 内核前主要是 select 和 poll,自 Linux 2.6 内核正式引入 epoll 以来,epoll 已经成为了目前实现高性能网络服务器的必备技术。...mmap 将用户空间的一块地址和内核空间的一块地址同时映射到相同的一块物理内存地址(不管是用户空间还是内核空间都是虚拟地址,最终要通过地址映射映射到物理地址),使得这块物理内存对内核和对用户均可见,减少用户态和内核态之间的数据交换...内核可以直接看到 epoll 监听的句柄,效率高。 红黑树:红黑树将存储 epoll 所监听的套接字。...以下是一个简单的 Java AIO 示例 import java.io.IOException; import java.net.InetSocketAddress; import java.nio.ByteBuffer
而从步骤3到步骤5中间会涉及到大量 Linux IO 的原理,特别是Page Cache 和 Buffer Cache 等缓存。...Linux IO 缓存体系,stdio和内核缓存的区别,Page Cache和Buffer Cache的区别。 Buffered IO、mmap(2)、Direct IO的区别。...所以后面的讨论基本上是讨论 IO 相关的系统调用和文件系统Page Cache的一些机制。 Linux内核中的IO栈 这一小节来看 Linux 内核的 IO 栈的结构。先上一张全貌图[4]: ?...设备层,通过 DMA 与内存直接交互,完成数据和具体设备之间的交互 结合这个图,想想Linux系统编程里用到的Buffered IO、mmap(2)、Direct IO,这些机制怎么和 Linux IO...mmap(2)直接把Page Cache映射到了用户态的地址空间里了,所以mmap(2)的方式读文件是没有第二次拷贝过程的。那Direct IO做了什么?
前言: 在信息技术日新月异的今天,Linux操作系统以其强大的稳定性和灵活性,成为了服务器、嵌入式系统以及众多开发者心中的首选平台。...而在Linux系统的广阔天地中,I/O(输入/输出)操作无疑是连接用户与硬件、软件之间的桥梁,其性能的优化直接关系到整个系统的响应速度和数据处理能力。...深入探索Linux的I/O模型,我们不难发现,这些模型不仅仅是数据流动的通道,更是理解系统并发处理、资源调度以及性能调优的关键所在。...让我们一同开启这段充满挑战与收获的旅程,探索Linux高级I/O模型的奥秘,为打造更加出色的系统应用奠定坚实的基础。...总结 随着本文的收尾,我们共同完成了对Linux高级I/O模型中五种核心机制的深入探索。
) { while(1) { if (do_face() < 0) continue; do_exec(command); } return 0; } printf 是 C 库当中的 IO...函数,一般往 stdout 中输出,但是 stdout 底层访问文件的时候,找的还是 fd:1, 但此时, fd:1下标所表示内容,已经变成了myfile 的地址,不再是显示器文件的地址,所以,...FILE 因为IO相关函数与系统调用接口对应,并且库函数封装系统调用,所以本质上,访问文件都是通过fd访问的。 所以C库当中的FILE结构体内部,必定封装了fd。...]# stat test.c File: "test.c" Size: 654 Blocks: 8 IO Block: 4096 普通文件 Device: 802h/2050d Inode: 263715...[root@localhost linux]# touch abc [root@localhost linux]# ln abc def [root@localhost linux]# ls -1i
不止是这些的C语言中的对于代码的修改,在Linux操作系统上的echo进行重定向,也能够对文件内容进行修改,所以输出重定向一定是文件操作,并且每次重定向写入的方式是先清空,再写入,其实根本上,这个输出重定向也就是按照...open函数的第一种方式代表的通常都是操作一些已经存在的文件,因为如果直接创建的话,在Linux操作系统中,我们不知道,我们创建的文件的权限是什么,所以说有的时候还会让我们创建的文件的权限出现乱码的情况...1、创建file 2、开辟文件缓冲区的空间,加载文件数据 3、查进程的文件描述表 4、file地址填入对应的表小表中 5、返回下标 话又说回来,其实read和write函数本质上也就是拷贝函数。...由于Linux操作系统一切皆文件,所以其中显示器,键盘的外设,也能够存在于sturct file链表中,所以就有了之前的0,1,2。 对于硬件来说的一切皆文件示意图。
对应到Linux的Page Cache上所谓Write Through就是指write(2)操作将数据拷贝到Page Cache后立即和下层进行同步的写操作,完成下层的更新后才返回。...Linux下Buffered IO默认使用的是Write back机制,即文件操作的写只写到Page Cache就返回,之后Page Cache到磁盘的更新操作是异步进行的。...磁盘的性能测试 在具体的机器上跑服务程序,如果涉及大量IO的话,首先要对机器本身的磁盘性能有明确的了解,包括不限于IOPS、IO Depth等等。...一般SSD的IO Depth都在32甚至更高,使用32或者64个线程才能跑满一个SSD磁盘的带宽(同步IO情况下)。 具体的SSD原理不在本文计划内,这里给出一篇详细的参考文章[7]。...写在最后 每天抽出不到半个小时,零零散散地写了一周,这是说是入门都有些谬赞了,只算是对Linux下的IO机制稍微深入的介绍了一点。
Linux Asynchronous I/O Explained (Last updated: 13 Apr 2012) ***********************************...Linux kernel provides only *5* system calls for performing asynchronoes I/O....There are two main libraries in Linux that facilitate AIO, we will refer to them as *libaio* and *librt...Types and constants exported to the user space reside in "/usr/include/linux/aio_abi.h" header file....原文链接:https://www.fsl.cs.sunysb.edu/~vass/linux-aio.txt
前言 Linux 文件 IO 操作指的是在 Linux 系统上对文件进行读取和写入的操作。它是通过与文件系统交互来读取和写入文件中的数据。...在 Linux 中,文件被视为一系列字节的有序集合,每个文件都有一个相关联的文件描述符,用于标识该文件的唯一标识符。文件 IO 操作允许程序从文件读取数据或将数据写入文件。...文件 IO 操作通常包括以下几个主要方面: open函数 int open(char *pathname, int flags); -->#include 参数: pathname...与睡眠状态相对的是运行状态,在Linux内核中,处于运行状态的进程分为两种状态: 正在被调度执行。...CPU处于该进程的上下文环境中,程序计数器里保存着该进程的2指令地址,通常寄存器里保存着该进程运算过程的中间结果,正在执行该进程的指令,正在读写该进程的地址空间 就绪状态。
本文主要讨论磁盘IO操作,故只聚焦于Local Disk的访问特性和其与DRAM之间的数据交互。 无处不在的缓存 ?...图中描述了Linux下文件操作函数的层级关系和内存缓存层的存在位置。中间的黑色实线是用户态和内核态的分界线。...在Linux下,文件的缓存习惯性的称之为Page Cache,而更低一级的设备的缓存称之为Buffer Cache....综上,既然讨论Linux下的IO操作,自然是跳过stdio库的用户态这一堆东西,直接讨论系统调用层面的概念了。对stdio库的IO层有兴趣的同学可以自行去了解。...所以下篇的讨论基本上是讨论IO相关的系统调用和文件系统Page Cache的一些机制。 (未完待续...)
领取专属 10元无门槛券
手把手带您无忧上云