刚开始写博客不足之处望大家多多指点, 少一些质疑多一些帮助, 我们就能成为朋友.
上一篇:《.NET 程序员我是如何通过一个产品在 2 年内买车买房》有很多同为程序员的小伙伴们给我留言, 从整体的留言中我能看到有很多迷茫的小伙伴活在上班拿工资的夹缝中, 首先能挣到外快固然是好, 如没有挣到还是努力把自己的事做好, 成功并非都是顺理成章而是偶然, 能通过从事技术这份工作抓住机会才是你职场中应该学的, 比如: 你的每一任老板都是一个商机, 他是怎么做的你也可以这样做, 为什么不能, 应该是执行力不够, 上一篇我也讲到过我通过自媒体平台连续每天发文长达 2-3 个月, 其中这个过程就是一个漫长而又头疼的事, 首先每天的文章该怎么写就单单这一件事都足以让你放弃 100 次.
本文大纲:
1. 我热衷技术但我更倾向于技术变现
2. 代码可以 copy 发现商机的方式也可以 copy
3. 具体执行细节
4. 我的第二款产品现在正在这样做, 不信你搜搜看
1. 我热衷技术但我更倾向于技术变现
要想技术变现就必须广而告之, 你做的再好没人知道, 卖不出去也是一堆废代码, 因为没有价值(钱), 这里并非否认技术没价值, 而是要让技术变的更有价值, 让自己更有动力去学习技术, 然后通过技术变现, 通过技术在遇到实际情况的时候去解决, 让问题去驱动学习, 而不是学而不用, 最后沦落成为纸上谈兵.
以下是我在解决投票系统慢, 卡上面关于数据库的一些优化, 有可能你并没有遇到过该问题, 但是我遇到了并且总结成经验告诉你, 这就叫经验分享, 我把他整理成测试案例使你更能看明白.
一: 引擎的选择
为自己创造问题环境并去解决. 如需要测试 MySQL 表大数据量情况下如何优化, 首先第一步你会说我这里没有这么多数据如何去优化, 我可以告诉你如何快速生成百万千万数据量的最简单方法.
insert into `user`(phone,`name`,headimg,sex,addtime) select phone,`name`,headimg,sex,now() from `user`
以上 sql 语句是快速复制插入表数据, 意思是从 user 表中查询数据并插入到 user 表中 (也可以是另外一张表如 user2). 如数据表中起始只有 1 条数据的话, 那么执行 17 次 13 万多数据, 19 次 52 多万数据, 20 次 100 多万数据, 21 次 200 多万数据, 22 次 400 多万数据, 每执行一次就在上一次基础上翻倍. 以上 sql 语句是最简单不过的一条语句, 不用写(来给自己增加能让你放弃创造问题环境难度的语句) 什么循环之类的语句, 你只用按鼠标左键执行个 10 几次即可.
- select substring(MD5(RAND()),1,20);# 随机生成 20 位字符串
- select CEIL(RAND()*100000000000);# 随机生成最多 11 位数字
以上查询小技巧奉上, 可能你会用到
其中数据库表引擎是: MyISAM 和 InnoDB 查询对比, user(MyISAM 引擎)和 user3(InnoDB 引擎)表数据都是 400 多万, 且数据都是一模一样
1. 使用 count(*)方式查询差距对比
- # 引擎是: InnoDB
- select count(*) from `user3`;
平均查询时间: 1.6 秒 ~ 1.8 秒
- # 引擎是: MyISAM
- select count(*) from `user`;
平均查询时间: 0.000 秒 ~ 0.001 秒
2. 使用 count(*) 和 count(id)方式查询差距对比
- # 引擎是: InnoDB
- select COUNT(*) from `user3`;
- select COUNT(id) from `user3`;
- # 其中 count(*)的方式要快于 count(id)差不多 0.1 秒 ~ 0.5 秒
- # 引擎是: MyISAM
- select COUNT(*) from `user`;
- select COUNT(id) from `user`;
- # 其中 count(*)和 count(id)差距在 0.000 秒 ~ 0.001 秒
3. 使用 like 方式查询差距对比
- # 引擎是: InnoDB
- select * from `user3` WHERE `name` like 'b981%';
- # 平均查询时间: 2.8 秒 ~ 3.068 秒
- # 引擎是: MyISAM
- select * from `user` WHERE `name` like 'b981%';
- # 平均查询时间: 0.959 秒
4. 使用带分页方式查询差距对比
- # 引擎是: InnoDB
- select * from `user3` WHERE `name` like 'b981%' limit 1,10;
- # 平均查询时间: 0.5 秒
- # 引擎是: MyISAM
- select * from `user` WHERE `name` like 'b981%' limit 1,10;
- # 平均查询时间: 0.1 秒
以下是 InnoDB 和 MyISAM 引擎的使用场景说明
InnoDB 存储(默认引擎): 对事务要求高, 保存的数据都是重要数据, 可以考虑使用 InnoDB 引擎, 比如订单表, 账号表
MyISAM 存储: 如表对事务要求不高, 同时以查询和添加为主, 可以考虑使用 MyISAM 引擎
二: 数据表分区
知识点说明: 投票系统使用的 HASH 方式进行分区的, 使用 HASH 方式好处: 当插入数据时, 根据 id 把数据平均散到各个分区上, 由于文件小, 效率高, 更新操作变得更快.
其他更多的分区可以查看
1. 创建带有分区的表, 最后一句代码就是创建 HASH 分区: PARTITION BY HASH (id) PARTITIONS 10
- CREATE TABLE `user4` (
- `id` int(11) NOT NULL AUTO_INCREMENT,
- `phone` varchar(11) DEFAULT NULL,
- PRIMARY KEY (`id`)
- ) ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8
- PARTITION BY HASH (id) PARTITIONS 10;
重点: 要使用分区表必须要在创建表的时候就设置好
问题: 但是表最开始没有创建分区该怎么办? 第一步: 将表结构代码导出, 在最后加上分区代码 PARTITION BY HASH (id) PARTITIONS 10, 创建一个新临时表. 第二步: 使用查询并插入的语句进行同步数据到新表, 同步完成将临时表表名改成正式表名, 将原来表删除或者换一个新名字. 当你在插入数据的时候就自动给你进行了分区. 分区表建立好之后下面我们就进行查询分析对比.
将数据同步到分区表(user4)
- insert into `user4`(phone,`name`,headimg,sex,addtime) select phone,`name`,headimg,sex,now() from `user`
- # 执行插入时间只有 12.526 秒, 如果未分区插入需要 30 多秒
1. 使用 count(*)方式查询差距对比, 加了 HASH 分区直接秒杀前两者
- # 引擎是: InnoDB
- select count(*) from `user3`;
- # 平均查询时间: 1.6 秒 ~ 1.8 秒
- # 引擎是: MyISAM
- select count(*) from `user`;
- # 平均查询时间: 0.000 秒 ~ 0.001 秒
- # 引擎是: MyISAM+HASH 分区
- select COUNT(*) from `user4`
- # 平均查询时间: 0.000 秒
2. 使用 count(*) 和 count(id)方式查询差距对比, 加了 HASH 分区直接秒杀前两者
- # 引擎是: MyISAM+HASH 分区
- select COUNT(*) from `user4`;
- select COUNT(id) from `user4`;
- # 平均查询时间: 0.000 秒
3. 使用 like 方式查询差距对比, 没有加 HASH 分区的表要快加了 HASH 分区表那么一丢丢, 你知道为什么吗, 留言回复?
- # 引擎是: MyISAM
- select * from `user` WHERE `name` like 'b981%';
- # 平均查询时间: 0.827 秒
- # 引擎是: MyISAM+HASH 分区
- select * from `user4` WHERE `name` like 'b981%';
- # 平均查询时间: 0.976 秒
以上两个知识点解决了投票系统很大一部分慢卡的问题, 其实也没有什么高大上, 还是那一句话: 适合自己的才是最好的. 当系统更流畅客户用的更顺心你向他要点钱都是分分钟的事.
2. 代码可以 copy 发现商机的方式也可以 copy
首先你要弄清楚你所做的产品卖点在哪里? 如何找到卖点(商机)?
方式一: 我是通过做定制开发, 找我开发同一个产品的人多, 就代表这个事有价值.
方式二: 你所任职的公司在做什么事, 你们公司所做的这款产品就是卖点(这里不说大厂如 BAT), 把公司这款产品翻版一份 min 版本调整价格, 通过在网上发软文(你完全可以去网上找, 上一篇文章也说过怎么找), 起码至少 2-3 个月的软文努力才有效果, 如果没有这个毅力那么最开始就不要想着去翻版.
方式三: 例如: 微擎的应用商店, 猪八戒的排名前几的服务商点进去看他们什么产品卖的好, 这些都是商机, 挑选一个在你能力范围内的产品进行翻版.
3. 具体执行细节
通过以上方式找准商机然后就开始开发产品
建立产品宣传的官网让你的产品更正式, 官网主要用于宣传产品的卖点和介绍产品的使用.
搜集友商的软文进行修改, 主要修改成自己的产品信息, 然后每天定时发送
每天将新闻发布到: 官网, 搜狐自媒体平台(推荐), 豆瓣, 简书, 贴吧
每天在友商软文下进行软留言(带有自己产品的关键字)
如有客户找上门要有一套说法, 每次将客户单独拉入一个群聊, 群内最好除了客户之外要有 2 人(你 + 售前也可以自己多个号), 你想想只有 2 个人的不叫群聊那叫尬聊
准备好合同, 如入住了平台, 平台方则担任担保.
4. 我的第二款产品现在正在这样做, 不信你搜搜看
你可以试着搜一搜: 玩具租赁, 就第一页里面的内容 (除了头部百度的广告外) 你都点进去要么是我的产品宣传官网, 要么是友商的软文(底下肯定有我的产品留言).
来源: https://www.cnblogs.com/shifubug/p/10627349.html