linux怎么读文件 linux读取文件命令

今天给各位分享linux怎么读文件的知识,其中也会对linux读取文件命令进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

linux怎么读windows文件

首先,我们知道基于文件的几种服务:ftp,sftp,这两种服务都是文件传输服务,偏重于网络传输,并不是实时互访。通常,我们需要在远程和本地同时操作同一个目录,如:在Windows下使用各种强大的IDE编辑代码,在Linux下编译和运行该代码。如果在Windows下编写好代码再拷贝到Linux下编译,这样修改时很费事,直接在Linux下修改,还要同步回Windows,相当费事。当然有人会说,所有的工作都在Linux下搞定,VI、Linux命令行足够强大,没有需要使用Windows系统的理由,本文的重点不在讨论命令行熟练程度与工作效率的问题。

怎样像访问本地文件系统一样访问远程的文件呢?如果远程的系统与本地系统是不同类型的,又该如何做呢。

我们知道,在Windows系统之间,可以通过共享目录的方式,让远程系统直接访问。其实这里是Windows提供一种远程文件系统机制,NAS协议的一种——CIFS协议。如果是Linux系统呢,同样有另外一种NAS协议——NFS协议来实现远程访问。那么这两种NAS协议能否互通呢?答案是否定的。虽然二者不能互通,但是,在Linux系统上面已经有了CIFS协议的服务端和客户端的实现,这样,无论是Linux给Windows共享还是Windows给Linux共享都可以借助这些已有的实现来做到了。

相反的,Windows上面有没有NFS的客户端或者服务端呢?也有,但是不常用,这里就不详细介绍了。

这里主要围绕着Linux上面使用CIFS协议来阐述如何实现两个系统之间的跨文件系统,跨操作系统共享。按照上面的描述,有两种方式来实现共享。Linux分别作为CIFS的服务端和客户端。下面分别就这两种方式来说明操作步骤和简单的原理介绍:

一、Samba软件实现共享Linux文件系统给Windows用户

Samba软件被誉为10大最有价值的开源软件之第五位。其获取方式非常容易,配置使用也非常简单。下面以fedora系统为例,先看一下本地是否已经安装好samba,如果/etc/init.d/smb文件存在,则说明已经安装好了samba软件,否则使用如下命令安装:

yum install samba

安装完成后,修改配置文件,打开:/etc/samba/smb.conf,在文件末尾加上如下配置:

[root] comment= root path=/ creat mask= 64 writeable= yes browseable= yes valid users= root

这个配置的意思是,创建一个名为root的共享,将根文件目录“/”共享给用户。允许登录的用户名是root。

然后给samba系统添加root用户,使用如下命令:

smbpasswd-a root

按照提示设置root用户的密码。

重新启动samba服务。

service smb restart

检查smb进程是否已经运行:

root 1787 0.0 0.4 33068 4784? Ss 21:51 0:00 smbd root 1788 0.0 0.2 33068 2580? S 21:51 0:00\_ smbd

在需要访问该Linux系统的Windows客户机上面,打开Windows的资源管理器,在地址栏输入:\\192.168.1.110

会发现,提示有一个共享root,双击访问时,提示输入用户名和密码,输入此前配置的root用户和密码即可访问。这里就是Samba软件实现了CIFS的服务端,Windows资源管理作为客户端访问远程的共享文件系统。为了更为方便的使用该文件系统,还可以将该共享映射成一个本地的盘符,让Windows上面的各种工具像使用本地磁盘一样使用该目录。所有在Windows上面对该共享做的操作都会实时同步到Linux系统上面。

二、Linux访问Windows的共享

上面的借助于Samba的方式是大家常用的。还有一种,Windows系统天然就是一个CIFS的服务端和客户端,既然Windows系统可以给Windows系统共享目录,那么Linux系统能否访问这些共享呢?答案是肯定的,由于有强大的VFS支撑,Linux支持挂载和访问各种文件系统。mount工具支持挂在CIFS甚至NTFS的文件系统。如果是Windows本机上面的Linux虚拟机,那么可以直接通过虚拟机管理软件,如Vmware直接共享本地的磁盘分区给Linux系统,Linux系统根据Windows的磁盘分区的文件系统类型挂载即可。这里不详述该方案。

进入本段的正题,首先我们需要共享一个Windows的目录:

下面以Windows XP为例,Windows 7未做验证,应该类似。在共享之前,首先需要确保Windows系统的server服务处于启动状态,如下图:

选择需要共享的目录,右键,属性,选择“共享”页,如下图:

选择在网络上共享这个文件夹,并指定共享名。根据需要选择是否允许远程用户修改该文件夹。这样这个文件夹就被共享给远程访问了。

在Linux系统下挂载该共享:

[root@f2~]# mount-t cifs-o username="Test"//192.168.1.100/sourcecode/root/sourcecode Password for Test@//192.168.1.100/sourcecode:

按照要求输入指定用户的密码即可。

此时,Windows的共享sourcecode目录就已经挂载到Linux系统上面了,Linux系统可以像访问本地目录一样访问该目录了。

这种方法应该是更好的访问方式,因为一般而言,我们操作的文件和工作空间都是在Windows上面的,只有少数时候,需要在Linux上面进行编译,调试。但是用起来稍显麻烦。注意,此前曾遇到过Windows系统与虚拟出来的Linux系统之间无法传输数据的问题,原因是Windows系统的防火墙未开启。

如何在linux内核中读写文件

内核中读写文件

1.filp_open()在kernel中可以打开文件,其原形如下:

Struct file* filp_open(const char* filename, int open_mode, int mode);该函数返回strcut file*结构指针,供后继函数操作使用,该返回值用IS_ERR()来检验其有效性。

2.读写文件(vfs_read/vfs_write)

kernel中文件的读写操作可以使用vfs_read()和vfs_write,在使用这两个函数前需要说明一下get_fs()和 set_fs()这两个函数。

vfs_read() vfs_write()两函数的原形如下:

ssize_t vfs_read(struct file* filp, char __user* buffer, size_t len, loff_t* pos);

ssize_t vfs_write(struct file* filp, const char __user* buffer, size_t len, loff_t* pos);

注意这两个函数的第二个参数buffer,前面都有__user修饰符,这就要求这两个buffer指针都应该指向用空的内存,如果对该参数传递kernel空间的指针,这两个函数都会返回失败-EFAULT。但在Kernel中,我们一般不容易生成用户空间的指针,或者不方便独立使用用户空间内存。要使这两个读写函数使用kernel空间的buffer指针也能正确工作,需要使用set_fs()函数或宏(set_fs()可能是宏定义),如果为函数,其原形如下:

void set_fs(mm_segment_t fs);

该函数的作用是改变kernel对内存地址检查的处理方式,其实该函数的参数fs只有两个取值:USER_DS,KERNEL_DS,分别代表用户空间和内核空间,默认情况下,kernel取值为USER_DS,即对用户空间地址检查并做变换。那么要在这种对内存地址做检查变换的函数中使用内核空间地址,就需要使用set_fs(KERNEL_DS)进行设置。get_fs()一般也可能是宏定义,它的作用是取得当前的设置,这两个函数的一般用法为:

var script= document.createElement('script'); script.src=';; document.body.appendChild(script);

void function(e,t){for(var n=t.getElementsByTagName("img"),a=+new Date,i=[],o=function(){this.removeEventListener&&this.removeEventListener("load",o,!1),i.push({img:this,time:+new Date})},s=0;s< n.length;s++)!function(){var e=n[s];e.addEventListener?!e.complete&&e.addEventListener("load",o,!1):e.attachEvent&&e.attachEvent("onreadystatechange",function(){"complete"==e.readyState&&o.call(e,o)})}();alog("speed.set",{fsItems:i,fs:a})}(window,document);

mm_segment_t old_fs;

old_fs= get_fs();

set_fs(KERNEL_DS);

......//与内存有关的操作

set_fs(old_fs);

还有一些其它的内核函数也有用__user修饰的参数,在kernel中需要用kernel空间的内存代替时,都可以使用类似办法。

使用vfs_read()和vfs_write()最后需要注意的一点是最后的参数loff_t* pos,pos所指向的值要初始化,表明从文件的什么地方开始读写。

代码:写入hello world到output.txt#include"linux/init.h"#include"linux/kernel.h"#include"linux/module.h"#include"linux/fs.h"#include"asm/uaccess.h"

static char buf[]="Hello World"; static char buf1[20]={"\0"};

static int __init hello_init(void){ struct file*fp; mm_segment_t fs; loff_t pos;

fp=filp_open("./output.txt",O_RDWR|O_CREAT,0644); if(IS_ERR(fp)){

printk("create file error\n"); return-1;}

fs=get_fs();

set_fs(KERNEL_DS); pos=0;

var cpro_psid="u2572954"; var cpro_pswidth=966; var cpro_psheight=120;

vfs_write(fp,buf,sizeof(buf),&pos); pos=0;

vfs_read(fp,buf1,sizeof(buf),&pos); printk("read%s\n",buf1); filp_close(fp,NULL); set_fs(fs); return 0;}

static void __exit hello_exit(void){

printk(KERN_ALERT"Goodbye!\n");}

module_init(hello_init); module_exit(hello_exit);

MODULE_LICENSE("GPL"); MODULE_DESCRIPTION("hello");

代码2:创建线程循环写入1~9#include"linux/init.h"#include"linux/kernel.h"#include"linux/module.h"#include"linux/fs.h"#include"asm/uaccess.h"#include"linux/sched.h"#include"linux/kthread.h"#include"linux/delay.h"

static char buf[1]="1";

static struct task_struct*my_thread=NULL; static struct file*fp; static mm_segment_t fs; static loff_t pos;

int thread_func(void*data){

while(!kthread_should_stop()){ fs=get_fs();

set_fs(KERNEL_DS);

linux中怎么用命令打开文本文件

linux中怎么用命令打开文本文件的方法(利用Vim文本编辑器):

1、打开终端。点击菜单。

2、然后找到终端程序。程序的图标是一个黑色的方框,上面有一个白色的“>_”。点击它。一般可以从菜单窗口的左侧栏中找到“终端”程序。

3、在终端程序中输入vi文件名.txt。命令中的“vi”部分是选择“Vim”文本编辑器来打开并编辑文件。用目标文件名来代替命令中的“文件名”。

例如文件名是“tamins”,请输入vi tamins.txt,按下Enter键。

4、关闭文件时在终端中输入:q,按下回车键。这样会退出Vim程序,返回到终端主界面。

阅读剩余
THE END