php实现含有redis命令的原子操作
在做一个爬虫,其中有一部分是评论数据。因为评论数太多,所以想要将爬取下来的评论进行分表。
目前的思路是:
每个表保存100万条数据(1-1000000保存在table1,1000001-2000000保存在table2)。
在redis创建一个String键comment:totalNum,保存数据库中已有的评论数。
根据 comment:totalNum 来确定评论的主键id以及保存到哪个表中。
目前思路是:
<code>$id = $redis->get( 'comment:totalNum' ); $tableName = getTableName( $id ); $sql = "insert xxx"; $res = $db->mysql_query( 'sql' ); if( $res ){ $redis->incr( 'comment:totalNum' ); } </code>
因为考虑用多线程,所以当一个表快要到100万条数据时,就会有一个问题:
如果一个进程获取了comment:totalNum为1000000,判断可以放在表一中,然后去执行对数据库的操作,但是如果此时也有一个进程获取了comment:totalNum的值,那么也会进行对数据库的操作,结果就会是数据库中增加了两条记录,一条主键为1,000,000,一条主键为1,000,001,不符合初衷。
所以我想问一下,有没有比较好的方法,能实现:
<code>原子操作 start $id = $redis->get( 'comment:totalNum' ); $tableName = getTableName( $id ); $sql = "insert xxx"; $res = $db->mysql_query( 'sql' ); if( $res ){ $redis->incr( 'comment:totalNum' ); } 原子操作 end </code>
回复内容:
在做一个爬虫,其中有一部分是评论数据。因为评论数太多,所以想要将爬取下来的评论进行分表。
目前的思路是:
每个表保存100万条数据(1-1000000保存在table1,1000001-2000000保存在table2)。
在redis创建一个String键comment:totalNum,保存数据库中已有的评论数。
根据 comment:totalNum 来确定评论的主键id以及保存到哪个表中。
目前思路是:
<code>$id = $redis->get( 'comment:totalNum' ); $tableName = getTableName( $id ); $sql = "insert xxx"; $res = $db->mysql_query( 'sql' ); if( $res ){ $redis->incr( 'comment:totalNum' ); } </code>
因为考虑用多线程,所以当一个表快要到100万条数据时,就会有一个问题:
如果一个进程获取了comment:totalNum为1000000,判断可以放在表一中,然后去执行对数据库的操作,但是如果此时也有一个进程获取了comment:totalNum的值,那么也会进行对数据库的操作,结果就会是数据库中增加了两条记录,一条主键为1,000,000,一条主键为1,000,001,不符合初衷。
所以我想问一下,有没有比较好的方法,能实现:
<code>原子操作 start $id = $redis->get( 'comment:totalNum' ); $tableName = getTableName( $id ); $sql = "insert xxx"; $res = $db->mysql_query( 'sql' ); if( $res ){ $redis->incr( 'comment:totalNum' ); } 原子操作 end </code>
1.mysql 基本上是单表1000w 数据,100w 量很小,不要急着分表
2.分表要根据需求来处理.
现在你需要保存聊天记录,可以根据时间维度进行分表,先做个统计,一天的数据量能达到多少,计算下大概多久可以达到1000w 的数据量,假设一个月数据量到达1000w, 那么就一个月一张表.
说下你现在方案问题,依赖性较强, redis 挂了或者数据丢失,你就需要手动处理.
如果按你现在的方案来做,要解决的是这个冲突问题,可以使用 redis的 watch 和 事务功能.
Talk is cheap. Show me the code
<code>$num = $redis->get("num"); $redis->watch("num"); //开启 mysql 事务 begin() //根据 num 插入数据到指定表中 insert xxxxxx //开启 redis 事务,进行递增 $redis->multi(); $redis->incr("num"); $incr = $redis->exec(); //如果在这期间,其他进程更改了 num 的值,会返回 false, 没有就返回递增后的值 if(! $incr ) { //回滚 }else{ //提交 mysql 事务 } </code>
根据评论的id号 取模 表的数量 然后在每个表平均的插入数据 你觉得是不是好点? 原子操作都可以不要了

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

If you are an experienced PHP developer, you might have the feeling that you’ve been there and done that already.You have developed a significant number of applications, debugged millions of lines of code, and tweaked a bunch of scripts to achieve op

Causes and solutions for errors when using PECL to install extensions in Docker environment When using Docker environment, we often encounter some headaches...

CMS stands for Content Management System. It is a software application or platform that enables users to create, manage, and modify digital content without requiring advanced technical knowledge. CMS allows users to easily create and organize content

Arrays are linear data structures used to process data in programming. Sometimes when we are processing arrays we need to add new elements to the existing array. In this article, we will discuss several ways to add elements to the end of an array in PHP, with code examples, output, and time and space complexity analysis for each method. Here are the different ways to add elements to an array: Use square brackets [] In PHP, the way to add elements to the end of an array is to use square brackets []. This syntax only works in cases where we want to add only a single element. The following is the syntax: $array[] = value; Example
