当前位置: 首页 > news >正文

白云营销型网站建设先备案 做网站

白云营销型网站建设,先备案 做网站,专业网页制作什么好,网站建设项目计划书使用Shell传参解决DataPhin中PySpark不支持中文的问题 背景 笔者开发PySpark任务时【别问为神马不用Java和Scala打Jar包的方式#xff0c;PySpark不需要打包所以开发效率极高#xff0c;早点搞完早点下班】#xff0c;遇到一个令所有SQL Boy都很头疼的问题#xff0c;那就…使用Shell传参解决DataPhin中PySpark不支持中文的问题 背景 笔者开发PySpark任务时【别问为神马不用Java和Scala打Jar包的方式PySpark不需要打包所以开发效率极高早点搞完早点下班】遇到一个令所有SQL Boy都很头疼的问题那就是一旦Python脚本中出现中文该PySpark任务就报错且无法运行。所以人才们当然是异常机智先搞个中间表把中文改成拼音PySpark跑完了再搞个Hive On Tez任务把拼音改回中文这种笨办法只适合于中文值的种类屈指可数的场景。 由于PySpark任务不能像Hive On Tez任务那样由DataPhin自动解析血缘和依赖还不支持中文所以SQL Boy们也是一度灰常嚣张总觉得Hive On Tez任务就是最好的任务。只有遇到Tez极其严重的性能问题才会想起来Spark的好处。 作为曾经的平台开发攻城狮自然是不能让这股风气蔓延不然大家都变成SQL Boy了还和Oracle数据库开发攻城狮有啥区别。。。势必解决这个问题。 解决方式 既然Py文件中不能写中文而我又要用中文那么借鉴Java开发中常见的前后端Json传参的方式我也可以Shell给Py文件动态传参这样Py文件中就完美的规避了中文的明文自然Py不会报错而参数值又可以让Python调用系统方法拿到。所以可以这么尝试 echo START cat zhiyong.py E0F # -*- coding: UTF-8-*import sys reload(sys) sys.setdefaultencoding(utf-8)from pyspark.sql import SparkSession spark SparkSession \.builder \.appName(project_week_his_incre_daily_prod) \.config(hive.exec.dynamic.partition,true) \.config(hive.exec.dynamic.partition.mode,nonstrict) \.getOrCreate()str_bizdatesys.argv[1]str_param1sys.argv[4].strip() str_param2sys.argv[5].strip() str_param3sys.argv[6].strip()sq11select str_param3 as str_param3 spark.sql(sql1).show()EOFhive_db1hive_db_name1 hive_db2hive_db_name2 STR1中文1 STR2中文2 STR3中文3spark-submit --master yarn --deploy-modeclient --driver-memory 4G --executor-memory 4G --executor-cores 1 --conf spark.dynamicAllocation.enabledtrue --conf spark.dynamicAllocation.minExecutors10 --conf spark.dynamicAllocation.maxExecutors50 --confspark.memory.fraction0.95 --confspark.shuffle.service.enabledtrue --conf spark.ui.port4180 --conf spark.port.maxRetries128--conf spark.rpc.timeout600s --conf spark.debug.maxToStringFields4096 --conf spark.sql.crossJoin.enabledtrue --conf spark.sgl.broadcastTimeout600s --conf spark.sql.autoBroadcastJoinThreshold-1 zhiyong.py ${bizdate} hive_db1 hive_db2 $STR1 $STR2 $STR3经过验证果然可以show出传入的中文参数 原理 这个cat重定向的py文件不支持直接写中文大概率是Encoder的问题。但是Shell本身可以正常写中文参数说明Linux Node的中文语言包和character set正常那么只需要在外层的Shell预先构建变量再通过spark-submit提交这个py文件时传入这些内容为中文的String参数即可在Python脚本中动态获取到变量的值再去拼接SQL字符串给Spark的算子使用。Python文件中依旧不能有明文的中文。 SQL和拼接的其它中文字符串的注释可以用#注释掉写在Shell的头上。 进一步排查 这么做给SQL Boy们使用已经足够了毕竟他们之前只搞过Oracle数据库开发当然也就只会SQL除此之外没啥会的东西了。 但是从平台开发的视角其实还是可以做进一步的分析。笔者的PyCharm一般是用Python3.7这么搞PySpark任务即便有中文也跑的很欢快。出现这种情况首先发现租来的阿里云DataPhin还是老掉牙的Python2.6那么 echo START cat zhiyong.py E0F # -*- coding: UTF-8-*给Py文件的头上个这玩意儿期望当然是可以识别中文。 但是本地、扔服务器都可以跑有中文参数/SQL的PySpark任务就是扔DataPhin跑不起来。。。 于是手动cat生成的py文件发现了惊天大秘密DataPhin解析有问题把#的这一行当Linux的注释给filter了。。。 属实无语的操作。。。 所以更改脚本的解析方式或者把基础环境的python升级到3.7都是个比shell传参更好的主意。平台的事情就不是SQL Boy能解决的了。 转载请注明出处https://lizhiyong.blog.csdn.net/article/details/129699142
http://www.hkea.cn/news/14271629/

相关文章:

  • 校园二手市场网站开发的意义国家对地理信息网站建设的重视
  • 专门做处理货的网站品牌策划的五个步骤
  • 建筑设计网站擅自使用他人产品做网站宣传
  • 天津河西做网站贵吗WordPress微信如何赚钱
  • 源码网站怎么搭建网站开发项目swot分析
  • 网站域名后缀代表什么意思天津河西做网站哪家好
  • 文化传播公司做网站宣传好吗江门建设银行网站
  • 布料市场做哪个网站好网站首页适合vue做吗
  • 体育php网站源码网站公司利润
  • 付运费送东西的网站怎么做6广告策划
  • 纪实摄影网站推荐广州海珠区发布
  • 群晖套件做网站网页的后缀名有那些
  • 企业网站建设网页wordpress 注册 登录界面
  • 东莞网站建设及外包1做网站的公司
  • 济南网站建设兼职专业建站分销商城
  • 学网站制作多少钱北京高端网页制作
  • 网站建设制作软件叫啥数字化转型的必要性
  • seo网站推广专员招聘图书馆网站开发总结
  • 网站制作需要什么资料打开上海发布
  • wordpress 多站 列表wordpress怎么添加主页
  • 企业网站建设综合实训心得织梦免费网站模块下载地址
  • 四川省城乡建设网站公司的官网建设
  • 在跨境网站贸易公司做怎么样福田庆三整过的明星
  • 美创网站建设优势南昌制作企业网站
  • 做网站后用浏览量百度给钱怎么安装wordpress模板安装教程
  • 衡水移动网站建设报价wordpress搜索内容
  • 做网站排在前十名要多少钱工程找队伍信息网
  • 财政局门户网站建设方案工程公司起名大全
  • 东莞专业网站建设推广2022年楼市最新政策
  • 品牌型网站制作价格wordpress怎么改静态