docker使用笔记

安装docker

  1. curl -sSL http://acs-public-mirror.oss-cn-hangzhou.aliyuncs.com/docker-engine/intranet | sh -
  2. 非root用户使用docker sudo usermod -aG docker userName
  3. 重启电脑

在docker中部署mongodb

  • docker run –name mongo3 -p 27018:27017 -d -v /home/yahaa/dockerdata:/data/db mongo –auth
解释:
    --name mongo3 指定容器名字为 mongo3
    -p 27018:27017 指定本机端口27018和容器端口27018绑定
    -d 在后台中运行
    -v 把本地的 /home/yahaa/dockerdata挂载到 /data/db
    mongo 表示自动拉取的镜像
    --auth 表示开启授权
  • docker exec -it mongo3 mongo admin
解释:
    终端进入容器 mongo3 并且执行容器中的命令 mongo admin
  • 然后创建一个user administrator:
db.createUser({
    user:"zihua",
    pwd:"123456789987654321", roles:[{role:"userAdminAnyDatabase",                    db:"admin"}
    ]}
);
  • 详情参考下面博文

    docker 中mongodb 授权

  • 参考博客

本地连接到阿里云mongodb

//连接MongoDB并指定端口

mongo 192.168.1.100:27017

//连接到指定的MongoDB数据库

mongo 192.168.1.100:27017/test

//指定用户名和密码连接到指定的MongoDB数据库

mongo 192.168.1.200:27017/test -u user -p password

mongodb使用总结

Mongodb修改为密码登录

  • 无密码登录到mongodb
mongo
  • 使用 admin这个数据库
use admin
  • 新建用户

    db.createUser(
       {
         user: "userName",
         pwd: "password",
         roles: [ { role: "userAdmin", db: "admin" } ]
       }
    )
    
  • 停止 mongodb

sudo service mongod stop
  • 启动验证登录
sudo mongod --auth
  • 重启 
sudo service mongod start
  • 密码登录到 mongodb
mongo --port 27017 -u "userName" -p "password" --authenticationDatabase "admin"

说明

  1. userName,password 为你想要添加的用户名以及密码,并且指定了数据库 admin ,拥有权限: userAdmin

  2. 数据库用户角色:read、readWrite;

  3. 数据库管理角色:dbAdmin、dbOwner、userAdmin;
  4. 集群管理角色:clusterAdmin、clusterManager、clusterMonitor、hostManager;
  5. 备份恢复角色:backup、restore;
  6. 所有数据库角色:readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase
  7. 超级用户角色:root
    // 这里还有几个角色间接或直接提供了系统超级用户的访问(dbOwner 、userAdmin、userAdminAnyDatabase)
  8. 内部角色:__system

编译原理研讨

第二题

设有文法 G[S’];

  1. S’ -> S
  2. S -> aS
  3. S -> bA
  4. A -> dA
  5. A -> d
  • 构造G[S]的LR(0)项目规范族 C={I0,I1,…,In}。
  • 说明G[S]属于哪一种LR文法,构造相应的LR分析表。
  • 写出句子aabbd的分析过程。

解答过程

  • 文法的项目
  1. S’ -> .S
  2. S’ -> S.
  3. S -> .aS
  4. S -> a.S
  5. S -> aS.
  6. S -> .bA
  7. S -> b.A
  8. S -> bA.
  9. A -> .dA
  10. A -> d.A
  11. A -> dA.
  12. S -> .d
  13. S -> d.

单机文件系统之Linux文件系统

单机文件系统之Linux文件系统

袁子华 14122260

目录

  • 引入
  • 硬盘的组成回顾
  • 分区的概念
  • Linux 文件系统 (VFS 虚拟文件系统)
  • 基于Linux 虚拟文件系统的一些验证性实验
  • 参考文献

引入

  • 在安装多系统的情况下,为什么Linux 系统能够直接访问其他系统的文件?
  • u盘在Linux 下被当作什么看待?
  • 如何有效的把云服务器的硬盘用起来?

演示

系统挂载设备操作
  • 查看系统已挂载设备 sudo df -h
  • 查看系统支持的文件系统 ls -l /lib/modules/$(uname -r)/kernel/fs
  • 系统已经加载到内存的文件系统 cat /proc/filesystems
  • 挂载设备 sudo mount /dev/xxx xxx目录
  • 强制卸载设备 sudo umount /dev/xxx
nfs文件系统配置脚本使用说明(服务器端 需要 root 权限) 代码地址
  • git clone git@github.com:yahaa/path_script.git
  • cd path_script
  • sudo su
  • python nfs_service.py
  • 停止服务 python nfs_umount.py
nfs 客户端配置(需要 root 权限)
  • git clone git@github.com:yahaa/path_script.git
  • cd path_script
  • sudo su
  • python nfs_client.py
  • 卸载 nfs python nfs_umount.py

硬盘的组成

  • 磁盘由一个一个盘片组成如下图,图中灰色同心圆为磁道。
  • 绿色部分为扇区,扇区是最小的存储单位,每个扇区为 512 bytes 。
盘片结构

图 1


  • 将扇区组成一个圆,即构成柱面,柱面是分区的最小单位
名称
  • 磁头(head)
  • 磁道(track)
  • 柱面(cylinder)
  • 扇区(sector)
  • 圆盘(platter)
    容量
  • 存储容量 = 磁头数 × 磁道(柱面)数 × 每道扇区数 × 每扇区字节数
  • 例如 图2中磁盘是一个 3个圆盘6个磁头,7个柱面(每个盘片7个磁道) 的磁盘,图2中每条磁道有12个扇区,所以此磁盘的容量为 6712*512 字节。

磁盘的整体结构

图 2

分区

  • 为什么要分区?
  1. 一整块磁盘很大,就像一个没与分层的衣柜,所有衣服都仍在里面很乱 .
  2. 把每个分区分开能一定程度确保数据安全
  3. 分区有助于系统性能提升

磁盘分区表作用示意图

图 3

  • 传统的分区方案,是将分区信息保存到磁盘的第一个扇区(MBR扇区)中的64个字节中,每个分区项占用16个字节,这16个字节中存有活动状态标志、文件系统标识、起止柱面号、磁头号、扇区号、隐含扇区数目(4个字节)、分区总扇区数目(4个字节)等内容。由于MBR扇区只有64个字节用于分区表,所以只能记录4个分区的信息。这就是硬盘主分区数目不能超过4个的原因。后来为了支持更多的分区,引入了扩展分区及逻辑分区的概念。但每个分区项仍用16个字节存储。
  • 假设硬盘的设备名为 /dev/hda 那么在Linux 系统中设备文件如下:
  1. /dev/hda1
  2. /dev/hda2
  3. /dev/hda3
  4. /dev/hda4

Linux 文件系统

  • “一切皆是文件” 是 Unix/Linux 的基本哲学之一.不仅普通的文件,目录、字符设备、块设备、 套接字等在 Unix/Linux 中都是以文件被对待;它们虽然类型不同,但是对其提供的却是同一套操作界面。
  • Linux 中允许众多不同的文件系统共存,如 ext2, ext3, vfat 等。通过使用同一套文件 I/O 系统 调用即可对 Linux 中的任意文件进行操作而无需考虑其所在的具体文件系统格式;更进一步,对文件的 操作可以跨文件系统而执行。
  • 为了实现以上两点,Linux 引入虚拟文件系统(VFS),缩略图如图4

VFS缩略图

图 4

VFS 思想

  • VFS 定义了所有文件系统都支持的基本的、概念上的接口和数据 结构;同时实际文件系统也提供 VFS 所期望的抽象接口和数据结构,与VFS的定义保持一致。(也就是说,一个文件系统要想被 Linux系统支持,那么该文件系统必须实现VFS所提供的接口)

VFS 数据结构 (参考博客)

  1. 超级块(struct super_block {…} )

    超级块是记录整个文件系统相关信息的地方,没有超级块,也就没有文件系统的说法.

  2. inode结构( struct inode {…} )

    该结构中存储的是一个特定文件的一般信息,对于一个基于磁盘的文件系统,该结构对应磁盘上的”文件数据控制块”。每一个inode结构都对应一个inode节点号,这个节点号是唯一的,它也唯一标识一个文件系统中的文件。

  3. dentry结构( struct dentry {…} )

    该结构存储的是目录实体和对应的文件的关联信息。

  4. file结构( struct file {…} )

    该结构中存储的是一个打开的文件和打开这个文件的进程间的交互信息。该结构保存在kernel的内存区,在打开文件时被创建,关闭文件时被释放。

Linux 的Ext2 文件系统(索引式文件系统)

  • Ext2与分区示意图如图5

详情

图 5

  • 详情对照

详情

图 6

  • inode 结构图如图7

inode

图 7

Ext2 的相关说明
  • 因为一个分区可能很大,可能会分成很多很多个block,为了便于管理,系统将这些block分成多个block组,每个block组中存储当前组的信息和当前block组的block .

  • inode中存储文件的一些属性信息,block中存储文件真正的内容,一个block的大小有1k、4k等大小,一个block中只能存储一个文件,比如现在有一个文件占据了一个block的1B大小,那么这个block剩余的大小也无法分配给其他文件使用。

    Ext2 相关名称
  • super block

    超级块,它记录的是整个文件系统的信息,文件系统的类型,inode数量,block数量等,每个分区的super block是相同的

  • 文件系统描述

    描述每个block group 的开始与结束的block号码。

  • 块对应表(block bitmap)

    用bit位记录了每一个block目前的状态,如果有数据就置为1,没有数据置为0。如果需要分配block,那么就找目前状态为0的。

  • inode 对应表(inode bitmap)

    和块对应表相似,记录的是inode的分配和未分配的号码。

  • inode table

    详细记录了每一个inode的信息。

  • data block

    详细记录文件数据的地方,每一个block都有block号码。

FAT 文件系统 (详情参考操作系统教材)

  • 大家都知道
  • u 盘使用的文件系统一般是FAT格式
  • 链式索引

NFS 文件系统

  • NFS 是Network File System 的缩写,其功能是通过网络,让不同的机器,不同的操作系统可以共享彼此的文件.
  • 工作原理示意图

NFS工作原理图

图 8

  • 服务端配置
import os
cmd = ['apt-get update', 'apt-get install nfs-kernel-server nfs-common',
   'mkdir /home/public', 'chmod -R 777 /home/public',
   'echo "/home/public  *(rw,sync,no_root_squash)" >>/etc/exports'
   , 'service rpcbind start', 'service nfs-kernel-server start']


def install():
for item in cmd:
    os.system(item)


if __name__ == '__main__':
install()
  • 客户端配置
import os
cmd = ['apt-get update', 'apt-get install rcpbind',
       'apt-get install nfs-client', 'service rpcbind start',
       'mkdir /home/nfsshare', 'mount -t nfs 115.29.146.79:/home/public /home/nfsshare',
       'chmod -R 777 /home/nfsshare']


def install():
    for item in cmd:
        os.system(item)


if __name__ == '__main__':
    install()
  • 卸载 NFS
import os
cmd = ['umount 115.29.146.79:/home/public',
       'service rpcbind stop', 'service nfs-kernel-server stop']


def shudown():
    for item in cmd:
        os.system(item)


if __name__ == '__main__':
    shudown()

参考文献

  • [1] 鸟哥.鸟哥的Linux私房菜基础篇.北京:人民邮电出版社,2017年3月:197-247.
  • [2] 鸟哥.鸟哥的Linux私房菜服务篇.北京:人民邮电出版社,2017年3月:393-420.
  • [3] Michael Beck,Harald Bohme.Linux内核编程指南.北京:清华大学出版社,2005年7月:108-135.

编译原理实验二


实验二词法分析(小组验收)

实验目的

  • 根据 PL/0 语言的文法规范,编写 PL/0 语言的词法分析程序。
  • 通过设计调试词法分析程序,实现从源程序中分出各种单词的方法;
    加深对课堂教学的理解;提高词法分析方法的实践能力。
  • 掌握从源程序文件中读取有效字符的方法和产生源程序的内部表示
    文件的法。
  • 掌握词法分析的实现方法。
  • 上机调试编出的词法分析程序。

Markdown语法入门

我久违的笔记

写给自己

很久前打算每天坚持写一些总结,日记用以记录自己的生活。

但是每次都被自己的懒惰给征服了,希望这次自己能坚持下去吧!

|