首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

从mongoDB中定时导出数据shell脚本

目标:编写一个shell脚本,以便能够将mongoDb中的数据导出成为csv格式的文件。要求:1. 为了避免导出巨量数据,仅需要过滤出当月数据和上个月的数据即可。2....由于当天的数据是不完整的,所以需要排除当天的数据以下是一个例子,将代码保存为.sh文件后使用 chmod +x 将该脚本设置为可执行,然后使用crontab命令将脚本加到定时任务当中 #!...baseDate declare -i baseTime baseTime=$((date --date "$baseDate" +"%s" * 1000)) 导出指定数据表中的数据...function exportData() { exportCmd="/kingdee/mongodb/bin/mongoexport --csv" if [ $# -gt 3 ]; then...else $exportCmd -d $1 -c $2 -f $3 -o $mypath/$2.csv fi } 导出第一张表的所有数据 echo export data

1.4K22
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    在Shell脚本中逐行读取文件的命令方法

    - 使用echo显示输出内容,输出内容包括自定义的字符串和变量,$rows变量为文本文件中的每行内容 Tips:可以将上面的脚本缩减为一行命令,如下: [root@localhost ~]# while...- 使用echo显示输出内容,输出内容包括自定义的字符串和变量,$rows变量为文本文件中的每行内容 Tips:可以将上面的脚本缩减为一行命令,如下: [root@localhost ~]# cat mycontent.txt...|while read rows;do echo "Line contents are : $rows";done 方法三、使用传入的文件名作为参数 第三种方法将通过添加$1参数,执行脚本时,在脚本后面追加文本文件名称.../bin/bash cat mycontent.txt |awk '{print "Line contents are: "$0}' 运行结果: 总结 本文介绍了如何使用shell脚本逐行读取文件内容...,通过单独读取行,可以帮助搜索文件中的字符串。

    9.2K21

    原 shell脚本中的逻辑判断,文件目录属

    shell脚本中的逻辑判断: 逻辑判断表达式:if [ $a -gt $b ]; if [ $a -lt 5 ]; if [ $b -eq 10 ]等 -gt (>); -lt(=);...-e file ]; then 表示文件不存在时会怎么样 if (($a<1)); then …等同于 if [ $a -lt 1 ]; then… [ ] 中不能使用,==,!...,或者被删除的话,脚本就会运行出错,出现bug 应该加上一个判断条件 #!...: 在网卡系统服务脚本中,如,/etc/init.d/iptables中就用到了case 在case中,可以在条件中使用“|”,表示或的意思 输入一个同学的分数,判断成绩是否及格,优秀。...input a number." exit 1 #判断$n1不为空时(即$n不是纯数字)再次提示用户输入数字并退出 fi #如果用户输入的是纯数字则执行以下命令: if [ $n -lt 60 ]

    1.5K51

    shell脚本中的逻辑判断,文件目录属性判断,if特殊用法,case语句

    笔记内容: 20.5 shell脚本中的逻辑判断 20.6 文件目录属性判断 20.7 if特殊用法 20.8/20.9 case判断 笔记日期:2017-11-22 20.5 shell脚本中的逻辑判断...Shell的代码不一定需要写在一个文件里,像这种简单的语句,完全可以直接在命令行中写成命令去执行,示例: ? 只不过每一个语句需要使用分号隔开。...关于shell中的逻辑运算符: &&  与 ||  或 20.6 文件目录属性判断 ? 在shell中经常会和文件和目录打交道,所以这个时候对文件或目录的判断就比较重要了。...综合以上的知识点演示一个脚本例题: ? ? 这个脚本是让用户输入一个数字,这个数字代表成绩分数,以这个分数来判断成绩属于什么等级,并且将结果打印出来。...其中脚本里第一行的read语句,是用来接收用户输入的内容的,然后这个内容会存储在n这个变量上。 还用到了sed命令,下面跟了个if判断,这一段代码是为了防止用户输入非数字的字符。 运行结果: ?

    3.6K30

    解决shell脚本中source etcprofile重载配置文件不生效的问题

    背景 最近在通过shell脚本在Linux系统安装Java或Python的过程中,遇到了shell脚本中的“source /etc/profile”无法生效的问题,虽然也可以在执行完脚本后再次执行“source...python3命令) 2.原因 执行脚本时,脚本中的命令是在子shell中执行,子shell只能继承父shell的环境变量,而无法修改父shell的环境变量,所做的修改仅对当前子shell有效。...(点) 用于使shell读取指定的shell文件,并依次执行文件中的所有语句 作用于当前shell进程 sh 执行指定shell脚本,在子shell中执行脚本中的语句 创建一个子shell,在新的namespace...中执行此脚本,继承父shell环境变量,但不改变父shell环境变量,仅对当前子shell有效 ./ 执行当前脚本文件,前提是待执行的文件具有可执行属性,等价于sh 创建一个子shell,在新的namespace...因为sh和bash是不同的shell,source命令是bash shell的内置命令,从C Shell 而来,而sh中没有source命令,所以用sh或者.

    9.2K31

    在shell程序里如何从文件中获取第n行

    我一直在使用 head -n | tail -1,它可以做到这一点,但我一直想知道是否有一个Bash工具,专门从文件中提取一行(或一段行)。 所谓“规范”,我指的是一个主要功能就是这样做的程序。...答: 有一个可供测试的文件,内容如下: 使用 sed 命令,要打印第 20 行,可写为 sed -n '20'p file.txt sed -n '20p' file.txt 测试截图如下: 要打印第...8 到第 12 行,则可用命令 sed -n '8,12'p file.txt 如果要打印第8、9行和第12行,可用命令 sed -n '8p;9p;12p' file.txt 对于行数特大的文件...可采用类似如下命令 sed '5000000q;d' file.txt tail -n+5000000 file.txt | head -1 需要关注处理性能的伙伴可以在上述命令前加上 time 再对大文件进行测试对比

    46020

    bash shell:脚本中修改profile文件更新LD_LIBRARY_PATH的示例

    sed编辑器被称作流编辑器(stream editor),跟普通交互式文件编辑器相反。在交互式编辑器中(比如vim),你可以用键盘命令来交互式地插入、删除或替换数据中的文本。...于是我们可以利用sed编辑器在安装脚本实现对profile文件的修改。...下面我们以一个实际应用的例子来说明: 我已经有一个叫CASSDK的项目,这个项目没有可执行文件,只是一组动态库文件提供别的应用程序调用(比如java),需要为它写一个安装脚本,脚本的作用是将在将文件复制到指定安装目录...另外还要写一个卸载脚本,在删除安装目录后,同时将profile中的LD_LIBRARY_PATH变量也同步修改。...,在文件末尾添加export语句INSTALL.sh # 定义安装目录位置的变量 cassdk_path=/home/gdface/cassdk # 定义要在profile中搜索的行 new_export

    3.1K20

    如何把.csv文件导入到mysql中以及如何使用mysql 脚本中的load data快速导入

    1, 其中csv文件就相当于excel中的另一种保存形式,其中在插入的时候是和数据库中的表相对应的,这里面的colunm 就相当于数据库中的一列,对应csv表中的一列。...3,在这里面中,表使用无事务的myISAM 和支持事务innodb都可以,但是MyISAM速度较快。...4, String sql = "load data infile 'E://test.csv' replace into table demo fields terminated by ',' enclosed... by '\\'' lines terminated by '\\r\\n'  (`A`,`B`) "; 这句话是MySql的脚本在java中的使用,这个插入速度特别快,JDBC自动解析该段代码进行数据的读出...如果要使用load data直接进行执行一下这句话,(不过要记得更改成自己的文件名  和 表名)就可以把文件中的内容插入,速度特别快。

    5.8K40

    Shell 从日志文件中选择时间段内的日志输出到另一个文件

    Shell 从日志文件中选择时间段内的日志输出到另一个文件 情况是这样的,某系统的日志全部写在一个日志文件内,所以这个文件非常大,非常长,每次查阅的时候非常的不方便。...我简单些了一个脚本来实现了这个效果。 不过我的实现不是最佳方案,性能上还有很大的优化空间,但我目前水平有限,没有想到更好的方法。...实现 shell 脚本 # 设定开始时间 s='2017/08/01 0:0:0' # 设定结束时间 e='2017/08/01 24:0:0' # 读取 3.log 这个原始文件,并且逐行循环 cat...问了下同事,shell 兼容性问题是一个很常见的问题。 优化这个脚本 同事给出了一个新的语法,不甚理解,但是据说效率会提升很多。...参见 Shell 命令行 从日志文件中根据将符合内容的日志输出到另一个文件 以上脚本均在 mac 下测试通过,在 linux 下可能会有稍许不同。

    1.8K80

    Linux: Shell脚本中处理文件路径参数,兼容相对路径与绝对路径

    在编写Shell脚本时,处理文件路径参数是一个常见的需求。路径参数可能是相对路径或绝对路径,如何编写一个兼容两者的Shell脚本并进行路径检查,是本文的主要内容。...一、问题背景与需求 在处理文件路径时,我们需要: 兼容相对路径和绝对路径的输入。 检查路径是否有效,即路径所指向的文件或目录是否存在。...路径检查:检查路径是否存在,并确认其是文件还是目录。 三、具体实现 以下是一个Shell脚本的示例,实现了上述功能: sh #!...路径类型判断:使用[[ " 路径检查:使用[ -e " 五、总结 通过上述脚本,我们可以兼容处理相对路径和绝对路径,并进行有效性检查。...这不仅提高了脚本的灵活性,还增强了健壮性,避免因路径问题导致的错误。

    75310

    数据库同步 Elasticsearch 后数据不一致,怎么办?

    2.2 比较脚本的实现 以下是一个简单的 Shell 脚本示例,用于比较 Logstash 输出文件(JSON 格式)和 PostgreSQL 数据库中的数据。...该脚本将比较特定字段(如 id)以确定哪些数据可能未导入到 Elasticsearch。.../compare.sh 此脚本会比较 logstash_output.log 和 postgres_data.csv 文件中的 ID。...使用 Redis 的优点是它能在内存中快速处理大量数据,而不需要在磁盘上读取和写入临时文件。 4、小结 方案一:使用 Shell 脚本和 grep 命令 优点: (1)简单,易于实现。...如果处理的数据量较小,且对速度要求不高,可以选择方案一,使用 Shell 脚本和 grep 命令。这种方法简单易用,但可能在大数据量下表现不佳。

    55110
    领券