zoukankan      html  css  js  c++  java
  • 初探Linux



    这是一个小小新手根据自己对Linux的理解而写下的笔记,记录的是大体的学习内容。记录的笔记不全面,甚至没有整体的概念,但也希望能够给部分人一些入门的帮助,实机基于CentOS 7。


    导语:学习一件新事物先从大体把握,了解其组成部分然后再分模块去学习,笔者是依据这样写下笔记的


    1. 系统的组成

    Linux的组成可大致分为:内核shell文件系统应用程序

    内核(Kernal):Linux最主要的部分,操作整个计算机的资源,提供内存管理,进程管理,驱动管理等基本功能

    Shell:提供用户与内核进行交互的接口,Shell是一个解析器负责解析命令,将用户传过来的命令解析过后通知内核执行相应的服务、Shell也可以解析Shell脚本,即Shell脚本可以像用户传命令过来一样有被执行的能力

    文件系统:提供文件存储、管理等功能。Linux抽象出虚拟文件系统以便适应不同类型的文件系统

    应用程序:计算器,编辑器,GIMP等






    2.文件系统

    从一切皆对象的Java变成一切皆文件的Linux了,因为Linux的系统资源都是以文件形式存在。首先来了解文件系统,其实就是认识各种目录结构及其作用,这里的内容有个印象即可,真要用到回来再看看


    2.1 文件系统结构

    • / :根目录
    • /bin:二进制可执行文件,即常用的命令(cd、ls、mkdir)
    • /sbin:二进制可执行文件,root专属命令
    • /boot:系统引导文件
    • /dev:设备文件
    • /etc:系统配置文件
    • /home:各用户的目录
    • /root:管理专属目录,不放在home下
    • /var:运行时需要改变数据的文件
    • /lib :库
    • /usr :系统应用程序
    • /tmp:各种临时文件
    • /opt:第三方应用程序
    • /proc:系统内存映射,虚拟文件系统
    • /mnt:临时文件系统挂载点
    • /media:移动设备挂载点

    2.2 文件类型、权限、组

    # 文件类型
    –:普通文件
    d:目录文件
    b:块文件
    c:字符文件
    l:符号链接文件
    p:管道文件pipe
    s:套字节文件socket
    
    
    # 权限
    r:可读,表示文件可读,目录可看列表
    w:可改,表示文件可改,目录可在内部新建和删除文件
    x:可运行,表示文件可运行,目录可进入
    可用数字表示:4=r,2=w,1=x
    467分别表示:可读,可读可写,可读可写可运行
    

    输入命令cd /ls -l显示根目录文件,首字母就表示文件类型,剩余表示权限,之后的数字表示连接数,跟着两个是所有者和所属组


    2.3 关于文件目录的命令

    cd:进入目录
    ls:列出目录
    mkdir:创建目录
    touch:创建文件
    mv:移动文件
    rm:删除
    cp:复制
    

    2.4 文件打包与压缩

    归档:也称打包,将多个文件或目录一起建立归档,一般是形成 .tar 文件

    压缩:利用算法对文件进行处理,达到压缩大小的目的

    注意:是不能直接压缩目录的,将多个文件或目录打包成一个 .tar 文件然后才能进行压缩,所以打包和压缩一般是同时进行的。压缩格式有:bz2,xz,zip,gz(最常见)

    tar -zcvf:选项从左到右表示gzip压缩,打包文件,显示过程,指定文件名
    tar -zxvf:其中z表示解压缩(同一选项不同功能),x表示解包
    tar -zcvf file.tar.gz  file:表示将file打包与压缩并命名为file.tar.gz,其后缀是为了方便辨认
    

    2.5 文本编辑器Vim

    在一切皆文件下,学会使用文本编辑器很关键,这里介绍Vim

    在没有学Vim之前,笔者进入文本编辑器看着命令行不知所措,乱按一通没有效果,只好关机重启,居然被小小的文本编辑器打败了,不好意思说是计算机专业的,这和windows的记事本完全不一样。在进入Vim之前,请先看清楚使用方法,不然进去就和笔者一样要重启解决


    一、Vim的三种模式:

    Normal:默认进入时的模式,输入会被当成命令

    i:进入Insert模式
    gg:跳转文头
    G:跳转文末
    /:查找
    n:下一个
    y:复制
    p:粘贴
    x:删除
    u:撤回
    

    Insert:输入的内容会插入到文件中(按 i 进入)

    ESC键:退出Insert,进入Normal模式
    

    Command :在Normal下输入会进入,在最后一行会有提示

    :q   不保存退出
    :q!  不保存强制退出
    :w   保存但不退出
    :w!  强制保存
    :wq! 强制保存退出
    :w [文件名] 另存为
    

    二、Vim的进入:

    vim 文件名:直接进入
    




    3. 应用系统


    3.1 应用程序安装

    Linux应用程序的安装可分为源码安装和二进制安装


    源码安装:是编写出的源代码,需计算机编译成二进制文件后才可进行安装,其编译时间较长,安装步骤繁杂,若安装过程中报错,新手是很难解决的,但也有优势:可自由选择需要的功能甚至可以改写源代码,因为是编译安装所以更适合自己的系统,效率和稳定性也有提升(笔者还未接触到,不做说明)


    二进制安装(举例rpm包管理器):是源码经过编译后的安装包,安装速度较快,不需要编译所以出错概率很小

    rpm安装是用默认安装路径的,不建议修改

    i:安装
    v:详情
    h:进度
    rpm -ivh 包全名:表示安装某一程序,注意要出现两次100%才是安装完成,第一次表示完成安装的准备
    

    rpm安装也有其缺点,因为程序间依赖关系复杂,若rpm安装过程中缺失依赖会报错,而且卸载时要从后安装的依赖开始卸载

    a:查询所有套件
    q:查询是否安装某软件
    |:管道符,将前面命令的输出交给后面的命令
    grep:搜索
    
    # 查询某程序是否安装
    rpm -qa | grep 程序包名
    
    

    查询 yum程序 是否安装


    这些程序安装都过于繁杂,有没有适合新手的? 当然有那就是yum了,yum是基于rpm的,所以也是二进制安装,安装速度较快,重要的是自动解决依赖问题,不需要手动下载


    yum安装

    y:安装过程中的选项都选择yes
    install:安装rpm软件包
    search:查看特定安装包
    update:更新rpm软件包
    check-update:检查是否有可用的更新rpm软件包
    remove:删除指定的rpm软件包
    
    

    这里举例 gcc程序 的安装,gcc是C语言编译器,这学期上Linux程序设计需要用到

    yum -y install gcc
    
    

    ![](https://img2020.cnblogs.com/blog/1737887/202003/1737887-20200311200802512-1303089816.png)

    从安装过程可以看到,yum会自动解决依赖关系,一键安装的感觉


    3.2 程序的打开

    常规的程序在命令行输入程序名即可打开,其安装在 $PATH下,即 /bin,/usr/bin,/usr/local/bin中,系统会去 $PATH 下查找,类似于windows下的环境变量


    其他程序则要主动去到程序的安装目录下输入启动文件来打开,假如要打开lampp

    /opt/lampp/./lampp start
    其中./表示当前目录,不然系统会去环境变量找
    
    

    或者将这个程序的安装目录加入到 $PATH中,这样就可以在命令行直接输入来启动程序了(类似windows下添加jdk环境变量)

    export PATH = $PATH:/opt/lampp
    
    




    4. Shell


    4.1 Shell编程

    Shell编程是对Linux命令的逻辑化处理,笔者笔记的自动上传也是用了Shell编程,不要觉得很深奥,其实有了编程语言的基础,几分钟就可以入门。笔者挑出部分基础说明,达到让大家认识Shell编程的目的即可


    简单入门

    touch helloWorld.sh		(新建一个helloWorld.sh文件,`后缀`只是为了方便辨认,没有实质作用)
    vim helloworld.sh       (文件中加入 echo "helloworld" ,echo表示输出,保存并退出vim)
    chmod +x helloworld.sh  (增加可运行的权限)
    ./helloworld.sh			(运行Shell脚本)
    
    

    是不是很简单?


    4.2 与Java的差异

    布尔运算 解释
    !
    -o
    -a
    关系运算符 解释
    -eq 数字是否相等
    -gt 大于
    -lt 小于
    字符串运算符 解释
    -z 长度是否为0,为0返回true
    str 是否为空

    if:(简单事例)

    a=1;
    b=1;
    
    if [ $a -eq $b ]
    then
       echo "equal"
    elif [ $a -gt $b ]
    then
       echo "大于"
    else
       echo "小于"
    fi
    
    

    for:(简单事例)

    #!/bin/bash
    
    for value in 1 3 5 7 9
    do
        echo $value
    done
    exit 0
    
    




    5. 内核

    内核提供进程管理,网络管理等功能,所以笔者将这些内容归到内核模块下


    5.1 进程--ps

    e:显示所有程序
    f:显示UID,PPIP,C与STIME栏位
    
    

    UID:用户ID
    PID:进程ID
    PPID:父进程ID
    C:优先级
    STIME:进程启动的时间
    TTY:使用终端
    TIME:CPU时间
    CMD:显示完整的启动进程所用的命令和参数
    
    

    5.2 进程--kill

    关闭进程,那么首先需要知道进程ID。假如关闭运行的vim

    ps -ef | grep vim
    kill [进程号]
    
    

    左边为开着的vim进程


    5.3 进程--前后台

    jobs:查看后台运行的进程
    fg:将后台进程转至前台
    bg:将前台进程转至后台
    在命令行最后加入 &:也是将前台进程转至后台
    
    

    这里将下载redis的任务加入后台(快捷键 Ctrl + z),用jobs查看后台进程,再用fg将其调至前台


    5.4 网络--端口


    netstat

    n:不DNS轮询,显示IP
    t:显示TCP端口
    u:显示UDP端口
    l:仅显示套接字
    p:显示进程标识符和程序名称
    
    # 查看80端口
    netstat -ntp | grep 80
    
    

    防火墙端口 firewall-cmd

    --query-port=<端口号>/<protocol>:查询指定端口
    --add-port=<端口号>/<protocol>:开放端口
    --remove-port=<端口号>/<protocol>:关闭端口
    
    --zone=public:作用域
    --permanent:永久生效
    --reload:重启防火墙
    
    
    # 查询是否开启
    firewall-cmd --zone=public --query-port=80/tcp
    
    # 开启防火墙端口
    firewall-cmd --zone=public --add-port=80/tcp --permanent
    
    # 重载防火墙
    firewall-cmd --reload
    
    



    这是笔者目前所浅显理解的Linux,Linux很优秀,需要在不断地使用中去挖掘



    参考:

    CentOS 7

    ​ 菜鸟教程

    《鸟哥的私房菜》



  • 相关阅读:
    String substring(int start,int end)截取当前字符串中指定范围内的字符串
    String字符串是不变对象,内容一旦创建不可改变,若改变一定会创建新对象
    StringBuilder修改字符串内容,增,删,改,插
    startsWith(),endsWith()判断当前字符串是否是以给定字符串开始或结尾的
    length()返回当前字符串的字符个数
    indexOf()字符位置
    charAt()检测回文
    手把手教你猜字小游戏
    release 和 drain
    c专家编程 ,c语言运行时环境
  • 原文地址:https://www.cnblogs.com/Howlet/p/12464994.html
Copyright © 2011-2022 走看看